
本文旨在提供关于在 PHP 中读取和写入 WebP 图像元数据的实用指南。WebP 格式原生支持 EXIF 和 XMP 元数据,本文将探讨如何利用 PHP 处理这些元数据,并提供修改 WebP 文件以包含元数据的示例代码,帮助开发者克服 “File not supported” 警告,实现对 WebP 图像元数据的有效管理。
WebP 元数据支持
WebP 格式基于 RIFF 容器,从设计之初就支持 EXIF 和 XMP 元数据块。这意味着,只要软件支持,WebP 图像可以包含与 JPEG 或其他格式图像相同的元数据信息。常见的元数据块包括 EXIF,XMP,ICCP,甚至 IPTC。
PHP 的 exif_read_data() 函数与 WebP
PHP 的 exif_read_data() 函数在处理 WebP 图像时可能会出现 “File not supported” 警告。这通常不是因为 WebP 格式本身不支持元数据,而是因为 PHP 的 EXIF 扩展可能没有正确配置或不支持 WebP 格式的元数据读取。
解决方法:
立即学习“PHP免费学习笔记(深入)”;
- 检查 PHP EXIF 扩展: 确保你的 PHP 环境已经安装并启用了 EXIF 扩展。
- 更新 EXIF 扩展: 尝试更新 EXIF 扩展到最新版本,以获得更好的 WebP 支持。
- 使用第三方库: 如果 exif_read_data() 仍然无法正常工作,可以考虑使用第三方库来读取 WebP 元数据,例如:Imagick 或 exiftool。
手动添加元数据块到 WebP 文件
如果需要手动向 WebP 文件添加元数据块(例如,从其他文件复制 EXIF 数据),可以使用以下方法:
RIFF 容器结构:
- 每个数据块(Chunk)由 4 字节的标识符(FourCC,例如 EXIF)开始,后跟 4 字节的小端字节序表示的数据块大小,然后是实际的数据负载。
- WebP 文件的第一个数据块以 4 字节的 RIFF 开始,然后是 4 字节的文件大小(减去 8 字节),最后是 4 字节的内容标识符 WEBP。
示例代码:
以下代码演示了如何将 EXIF 数据块添加到 WebP 文件:
<?php
$sExif = '...the binary data...'; // 从其他文件读取的 EXIF 二进制数据
$iLenExif = strlen($sExif); // 数据负载长度(字节)
// RIFF 容器需要 16 位对齐
if ($iLenExif % 2 == 1) {
$sExif .= "/0";
}
$hFile = fopen('TARGET.WEBP', 'r+'); // 读写模式打开文件
fseek($hFile, 0, SEEK_END); // 定位到文件末尾
fwrite($hFile, 'EXIF'); // 写入 4 字节的数据块 ID
fwrite($hFile, pack('V', $iLenExif)); // 写入 4 字节的数据负载长度(小端字节序)
fwrite($hFile, $sExif); // 写入实际数据
$iFilesize = ftell($hFile); // 获取新的文件大小
fseek($hFile, 4, SEEK_SET); // 定位到文件的第 5 个字节
fwrite($hFile, pack('V', $iFilesize - 8)); // 更新文件大小
fclose($hFile); // 保存更改
?>
代码解释:
- $sExif: 存储要添加的 EXIF 数据的二进制字符串。
- $iLenExif: 计算 EXIF 数据的长度。
- 16 位对齐: RIFF 容器要求数据块的长度是 16 位的倍数。如果数据长度是奇数,则添加一个空字节 /0 进行填充。
- 打开文件: 以读写模式 (r+) 打开目标 WebP 文件。
- 定位到文件末尾: 使用 fseek() 函数将文件指针移动到文件末尾。
- 写入数据块: 依次写入 EXIF 数据块的 ID (EXIF),数据长度(使用 pack(‘V’, …) 将长度打包成小端字节序),以及实际的 EXIF 数据。
- 更新文件大小: 获取新的文件大小,然后将文件指针移动到文件的第 5 个字节,更新文件大小(减去 8 字节,因为 RIFF 容器的文件大小不包括 RIFF 和文件大小字段本身)。
- 保存更改: 关闭文件,保存所有更改。
注意事项:
- 确保 $sExif 变量包含有效的 EXIF 数据。
- 在更新文件大小之前,务必先获取新的文件大小。
- 此方法假设 WebP 文件结构是标准的,并且可以安全地在文件末尾添加数据块。在处理复杂的 WebP 文件时,可能需要更复杂的逻辑。
总结
虽然 PHP 的 exif_read_data() 函数可能无法直接读取 WebP 图像的元数据,但 WebP 格式本身是支持 EXIF 和 XMP 元数据的。通过使用第三方库或手动修改 WebP 文件,可以在 PHP 中有效地处理 WebP 图像的元数据。在实际应用中,请根据具体需求选择最合适的方法。
以上就是WebP 图像元数据处理:PHP 实现方案的详细内容,更多请关注php中文网其它相关文章!


