PHP 脚本,用于从流行的多媒体文件格式中提取有用信息

v2.0.0-beta6 2023-11-02 19:40 UTC

README

可在 http://getid3.sourceforge.nethttps://www.getid3.org 获取

getID3() 采用多个许可证发布。您可以从以下许可证中选择,并根据许可证条款使用 getID3。

GNU GPL

GNU LGPL

Mozilla MPL

getID3 商业许可证

  • gCL (不再提供,现有许可证仍然有效)

上述许可证的副本包含在 getID3 发行版的 licenses/ 目录中。

如果您想捐赠,可以在 https://www.getid3.org 上找到 PayPal 捐赠链接。

快速入门

问:我如何检查 getID3() 在我的服务器/文件上是否正常工作?

答:将 getID3() 解压到目录中,然后访问 /demos/demo.browse.php

支持

问:我有一个问题,或者我发现了一个错误。我该怎么办?

答:请求支持和/或错误报告的首选方法是访问 http://support.getid3.org/ 的论坛。

Sourceforge 通知

强烈建议您注册 Sourceforge 的新版本发布通知。请访问: http://sourceforge.net/project/showfiles.php?group_id=55859 并点击小“监控包”图标/链接。如果您之前已注册邮件列表,请注意,该列表已被取消,现在将仅使用自动化的 Sourceforge 通知。

getID3() 做什么?

读取并解析(程度不同)

  • 标签

    • APE (v1 和 v2)
    • ID3v1 (& ID3v1.1)
    • ID3v2 (v2.4, v2.3, v2.2)
    • Lyrics3 (v1 & v2)
  • 有损音频

    • MP3/MP2/MP1
    • MPC / Musepack
    • Ogg (Vorbis, OggFLAC, Speex, Opus)
    • AAC / MP4
    • AC3
    • DTS
    • RealAudio
    • Speex
    • DSS
    • VQF
  • 无损音频

    • AIFF
    • AU
    • Bonk
    • CD-audio (*.cda)
    • FLAC
    • LA (Lossless Audio)
    • LiteWave
    • LPAC
    • MIDI
    • Monkey's Audio
    • OptimFROG
    • RKAU
    • Shorten
    • Tom's lossless Audio Kompressor (TAK)
    • TTA
    • VOC
    • WAV (RIFF)
    • WavPack
  • 音视频

    • ASF: ASF, Windows Media Audio (WMA), Windows Media Video (WMV)
    • AVI (RIFF)
    • Flash
    • Matroska (MKV)
    • MPEG-1 / MPEG-2
    • NSV (Nullsoft Streaming Video)
    • Quicktime (包括 MP4)
    • RealVideo
  • 静态图像

    • BMP
    • GIF
    • JPEG
    • PNG
    • TIFF
    • SWF (Flash)
    • PhotoCD
  • 数据

    • ISO-9660 CD-ROM 图像(目录结构)
    • SZIP(有限支持)
    • ZIP(目录结构)
    • TAR
    • CUE
  • 写入

    • ID3v1 (& ID3v1.1)
    • ID3v2 (v2.3 & v2.4)
    • VorbisComment on OggVorbis
    • VorbisComment on FLAC(非 OggFLAC)
    • APE v2
    • Lyrics3(仅删除)

要求

  • 对于 getID3() 1.7.x(及以前版本),PHP 4.2.0 至 5.2.x
  • 对于 getID3() 1.8.x(及以后版本),PHP 5.0.5(或更高版本)
  • 对于 getID3() 2.0.x(及以后版本),PHP 5.0.5(或更高版本)
  • 至少需要4MB内存用于PHP。强烈建议8MB或更多。加载所有模块后需要12MB。

安装

首选方法是使用composer。如果您还没有安装composer,请遵循安装说明

一旦安装了composer,请在项目根目录下执行以下命令来安装此库

composer require james-heinrich/getid3

使用

查看/demos/demo.basic.php,了解使用getID3()进行基本操作的示例,没有花哨的输出,仅扫描一个文件。

查看structure.txt以了解返回的数据结构。

请运行/demos/demo.browse.php以查看getID3()的完整目录浏览和文件扫描实现示例。

查看/demos/demo.mysql.php,了解一个示例递归扫描代码,该代码扫描给定目录中的每个文件以及所有子目录,并将结果存储在数据库中,允许进行各种分析/维护操作。

要分析通过HTTP或FTP远程文件,您需要在运行getID3()之前先将文件复制到本地。您的代码可能如下所示

<?php

// Copy remote file locally to scan with getID3()
$remotefilename = 'http://www.example.com/filename.mp3';
if ($fp_remote = fopen($remotefilename, 'rb')) {
    $localtempfilename = tempnam('/tmp', 'getID3');
    if ($fp_local = fopen($localtempfilename, 'wb')) {
        while ($buffer = fread($fp_remote, 8192)) {
            fwrite($fp_local, $buffer);
        }
        fclose($fp_local);
        // Initialize getID3 engine
        $getID3 = new getID3;
        $ThisFileInfo = $getID3->analyze($localtempfilename);
        // Delete temporary file
        unlink($localtempfilename);
    }
    fclose($fp_remote);
}

查看/demos/demo.write.php,了解如何写入标签。

返回的数据结构是什么样的?

请查看structure.txt

建议您查看/demos/demo.browse.php的输出,扫描您感兴趣的文件,以确认通常返回的数据结构以及您特定文件的数据,因为实际返回的数据可能因文件本身提供的信息而大相径庭。

注意

getID3() 1.x

如果格式解析器遇到一个关键问题,它将在$fileinfo['error']中返回某些内容,描述遇到的问题。如果生成一个不太关键的错误或通知,它将出现在$fileinfo['warning']中。这两个键可能包含多个警告或错误。如果['error']返回了某些内容,则表示文件没有正确解析,返回的数据可能正确或不完整。如果在['warning'](而非['error'])中返回了某些内容,则表示返回的数据是正确的——通常getID3()报告了文件中的错误,这些错误由于其他程序中已知的缺陷而被解决了。一些警告可能表明返回的数据是正确的,但某些数据由于文件中的错误而无法提取。

getID3() 2.x

请参阅以上内容,除了错误会被抛出(因此您只会得到一个错误)。

免责声明

getID3()已在许多系统、许多类型的文件和许多操作系统下进行了测试,通常被认为是稳定和安全的。但是,仍然有可能存在未被发现和/或未修复的缺陷,可能会损坏您的文件,尤其是在写入函数中。通过使用getID3(),您同意如果您的任何文件被损坏,这不是我的责任。实际上,我对任何事情都不负责:)

许可协议

GNU通用公共许可证 - 请参阅license.txt

此程序是自由软件;您可以在自由软件基金会发布的GNU通用公共许可证的条款和条件下重新分发和/或修改它;许可证的版本2,或(根据您的选择)任何较新版本。

此程序是在希望它会有用的希望下分发的;但没有任何保证;甚至没有关于适销性或特定用途适用性的暗示保证。有关详细信息,请参阅GNU通用公共许可证。

您应该已经收到一份GNU通用公共许可证副本,与该程序一起;如果没有,请写信给:自由软件基金会,Inc。59 Temple Place - Suite 330 Boston,MA 02111-1307,USA。

常见问题解答

问:我可以在我的程序中使用getID3()吗?我需要商业许可证吗?

A: 您可以自由地根据需要使用 getID3。唯一需要商业许可证的情况是,如果您正在销售集成了 getID3 的封闭源程序。如果您销售包含 getID3 的程序,只要您在销售时包含源代码副本,那就没问题。或者,您也可以不包含 getID3 分发您的代码,并说明“从 getid3.sourceforge.net 下载”。

为什么叫 "getID3()",而它实际上做了这么多的事情?

v0.1 实际上只做了那件事。我没有那么老的代码副本,但今天我可以用一个单行函数实现它。

function getID3($filename) { return unpack('a3TAG/a30title/a30artist/a30album/a4year/a28comment/c1track/c1genreid', substr(file_get_contents($filename), -128)); }

未来计划

https://www.getid3.org/phpBB3/viewforum.php?f=7

getID3() 中已知的问题/错误,可能最终会得到修复

https://www.getid3.org/phpBB3/viewtopic.php?t=25

  • 无法确定具有 VBR 视频数据的 MPEG 视频的比特率(需要文档)
  • 无法确定 MPEG 视频的交错/逐行扫描(需要文档)
  • MIDI 播放时间有时不准确
  • AAC-RAW 模式文件无法识别
  • WavPack-RAW 模式文件无法识别
  • mp4 文件报告大量 "未知 QuickTime 原子类型"(需要文档)
  • 加密的 ASF/WMA/WMV 文件警告 "未处理的 GUID ASF_Content_Encryption_Object"
  • 对于 NSV,无法计算音频和视频之间的比特率,只有总比特率。(需要文档)
  • 所有 Ogg 格式(Vorbis、OggFLAC、Speex)都受到大 VorbisComments 涵盖多个 Ogg 页面的问题的影响,但只有 OggVorbis 文件可以使用 vorbiscomment 处理。
  • 随 Mac OS 10.2.8 供应的 "head" 版本(可能还有其他版本)只理解单个选项(-n),因此失败。getID3 忽略此并返回错误的 md5_data。

getID3() 中已知的问题/错误,无法修复

https://www.getid3.org/phpBB3/viewtopic.php?t=25

  • 仅限 32 位 PHP 安装:由于 32 位 PHP 文件系统函数的限制,getID3() 无法始终完全解析大于 2GB 的文件。注意:自 v1.7.8b3 以来,对大于 2GB 的文件提供了部分支持,其中大多数将正常解析,只要没有关键数据位于 2GB 偏移量之外。已知的 will-work
    • 64 位 PHP 上的所有文件格式
    • ZIP(格式不支持大于 2GB 的文件)
    • FLAC(当前编码器不支持大于 2GB 的文件)已知 will-not-work
    • ID3v1 标签(始终位于文件末尾)
    • Lyrics3 标签(始终位于文件末尾)
    • APE 标签(始终位于文件末尾)可能-will-work
    • Quicktime(如果需要,在 2GB 偏移量之前的数据是必要的元数据,即如果文件已提示/优化用于流式传输,则可以正常工作)
    • RIFF.WAV(应该工作良好,但会发出无法解析所有块的通知)
    • RIFF.AVI(播放时间可能不正确,仅基于适合第一个 2GB 的 "movi" 块,应发出错误以显示播放时间不正确。其他数据应基本正确,假设数据在文件中保持不变)

其他程序中的已知问题/错误

https://www.getid3.org/phpBB3/viewtopic.php?t=25

  • Windows Media Player(最高版本 11)和 iTunes(最高版本 10+)不正确处理 UTF-16BE+BOM 编码的 ID3v2.3 标签(它们假设数据是 UTF-16LE+BOM,要么崩溃(WMP),要么输出亚洲字符集(iTunes))
  • Winamp(至少到v2.80版本)不支持ID3v2.4标签,仅支持ID3v2.3,请参阅: http://forums.winamp.com/showthread.php?postid=387524
  • 某些版本的Helium2(请访问www.helium2.com)不写入符合ID3v2.4规范的帧大小,尽管标签标记为ID3v2.4(由getID3()检测到)
  • MP3ext V3.3.17在ID3v2头部末尾放置了一个不符合规范的填充字符串。据说在v3.4b21中已修复,但前提是你手动添加了一个注册表键。此修复尚未得到确认。(由getID3()检测到)
  • CDex v1.40(在v1.50b7中修复)写入不符合规范的Ogg注释字符串,本应格式为"NAME=value",但实际上只写为"value"(由getID3()检测到)
  • Oggenc 0.9-rc3将编码的文件标记为ABR,无论它是ABR还是VBR。
  • iTunes(已知的“X v2.0.3”、“v3.0.1”版本是已知的有罪,可能还有其他版本也是如此)使用无效的帧名'COM '写入ID3v2.3注释标签,该帧名对ID3v2.3+无效(是ID3v2.2样式的帧名)(由getID3()检测到)
  • MP2enc不能正确地编码单声道CBR MP2文件(音速减半且播放时间加倍)
  • MP2enc不能正确地编码单声道VBR MP2文件(实际上编码为立体声)
  • tooLAME不能正确地编码单声道VBR MP2文件(实际上编码为立体声)
  • AACenc即使在指定CBR模式的情况下也会以VBR模式(实际上是ABR)编码文件
  • AAC/ADIF - 对于vbr文件,bitrate_mode = cbr
  • LAME 3.90-3.92在CBR模式下使用DLL编码时,会在前面添加一个空数据帧(用于LAME/VBR头部的空间,但从未写入)
  • Ahead Nero使用DSIZ值(本应表示字节数的文件大小)为"TwinVQF v1.0"的"0"和"TwinVQF v2.0"的"1"编码TwinVQF(由getID3()检测到)
  • Ahead Nero编码的TwinVQF文件比应有的时间短1秒
  • AAC-ADTS文件始终实际上以VBR模式编码,即使指定了CBR模式(编码器上的CBR模式开关启用ABR模式,而不是CBR模式,但无法区分此类ABR文件和真正的VBR文件)
  • OggFLAC中的STREAMINFO.audio_signature始终为空。"原因是libOggFLAC中还没有搜索支持,因此它无法在编码后返回并写入计算出的总和。Ogg FLAC的搜索支持是下一个版本的首要任务。" - Josh Coalson(FLAC开发者)注意:getID3()将以与其他文件格式类似的方法计算md5_data,但该值无法与FLAC文件格式中的FLAC数据中的md5_data值进行比较。
  • FLAC v0.3.0 & v0.4.0中不计算STREAMINFO.audio_signature - getID3()将以与其他文件格式类似的方法计算md5_data,但该值无法与FLAC v0.5.0+中的md5_data值进行比较。
  • RioPort(包括2.0和3.11在内的各种版本)使用没有数据部分的WCOM帧标记ID3v2
  • Coolplayer的早期版本会将非法ID3标签添加到Ogg Vorbis文件中,从而使文件损坏。
  • Meracl ID3 Tag Writer v1.3.4(及更早版本)在添加新的ID3v1标签时,不正确地截断MP3文件数据中的最后一个字节。(由getID3()检测到)
  • 使用和/或未使用-noseek开关编解码的Lossless-Audio文件在内部实际上不同,因此无法与md5_data匹配
  • iTunes已知会在存在ID3v2标签时在现有ID3v1标签的末尾添加一个新的ID3v1标签(由getID3()检测到)
  • MediaMonkey可能写入一个空的RGAD ID3v2帧,但将实际的重放增益调整放在一系列用户定义的TXXX帧中(自v1.9.2以来由getID3()检测和处理)

参考资料

www.id3.org资料现在镜像在http://id3lib.sourceforge.net/id3/