浅谈怎么利用PHP读取到图片的EXIF信息(附代码)

怎么利用PHP读取到图片的EXIF信息?下面本篇文章给大家介绍一下使用PHP获取图像文件的EXIF信息的方法,希望对大家有所帮助!

怎么利用PHP读取到图片的EXIF信息?下面本篇文章给大家介绍一下使用PHP获取图像文件的EXIF信息的方法,希望对大家有所帮助!

浅谈怎么利用PHP读取到图片的EXIF信息(附代码)

php入门到就业线上直播课:进入学习API 文档、设计、调试、自动化测试一体化协作工具:点击使用

在我们拍的照片以及各类图像文件中,其实还保存着一些信息是无法直观看到的,比如手机拍照时会有的位置信息,图片的类型、大小等,这些信息就称为 EXIF 信息。一般 JPG 、 TIFF 这类的图片文件都会有这样的信息。EXIF 其实就是专门为这种数码照片所定制的,专门用于记录数码照片的属性信息和拍摄数据的,最初由日本制定。这个其实很好理解,日本对相机行业基本是垄断般的存在,所以这类的标准当然就是由他们制定啦!

EXIF 在 Windows 系统中具有原生的支持,鼠标右键点击图片打开菜单,然后点击属性并切换到详细信息就可以直接看到图片文件的 EXIF 信息了。由于这些信息是可以被随意编辑的,所以它们可以作为一些参考,并不能作为某些功能属性的确定值来获取,比如宽高这些信息就不要完全相信 EXIF 中的。

获取 EXIF 中的图片类型信息

首先,我们看下通过 EXIF 来查看图片的类型。

var_dump(exif_imagetype($png)); // int(3)
echo exif_imagetype($png) == IMAGETYPE_PNG ? $png . ;是 PNG 图片; : $png . ;不是 PNG 图片;, PHP_EOL;
// ../img/1.png是 PNG 图片

var_dump(exif_imagetype($jpg)); // int(2)
echo exif_imagetype($jpg) == IMAGETYPE_JPEG ? $jpg . ;是 jpg 图片; : $jpg . ;不是 JPG 图片;, PHP_EOL;
// ../img/2.jpg是 jpg 图片登录后复制

直接使用 exif_imagetype() 函数就会返回一个图片类型的常量,也就是以 IMAGETYPE_ 开头的常量信息所代表的图片类型。它还包括其它很多类型,这里只是演示了我们平常最常见的 jpg 和 png 类型的图片类型的获取。

它和 getimagesize() 函数返回的第三个属性,也就是下标为 2 的那个属性的内容是一样的,在 getimagesize() 函数中,0 和 1 代表的是宽高,2 代表的就是图片的类型。

var_dump(getimagesize($jpg));
// array(7) {
// [0]=>
// int(300)
// [1]=>
// int(244)
// [2]=>
// int(2)
// [3]=>
// string(24) “width=”300″ height=”244″”
// [“bits”]=>
// int(8)
// [“channels”]=>
// int(3)
// [“mime”]=>
// string(10) “image/jpeg”
// }登录后复制获取完整的 EXIF 信息

图片中完整的所有 EXIF 信息是通过 exif_read_data() 函数来获取的。

var_dump(exif_read_data($png));
// PHP Warning: exif_read_data(1.png): File not supported in /Users/zhangyue/MyDoc/博客文章/dev-blog/php/202011/source/11.使用PHP获取图像文件的EXIF信息.php on line 14

// Warning: exif_read_data(1.png): File not supported in /Users/zhangyue/MyDoc/博客文章/dev-blog/php/202011/source/11.使用PHP获取图像文件的EXIF信息.php on line 14

// bool(false)

var_dump(exif_read_data($jpg));
// array(8) {
// [“FileName”]=>
// string(5) “2.jpg”
// [“FileDateTime”]=>
// int(1605061174)
// [“FileSize”]=>
// int(19075)
// [“FileType”]=>
// int(2)
// ……
// ……登录后复制

就像前面讲过的,EXIF 信息只在 JPG 、 TIFF 等类型的图片格式中存在,所以 PNG 图片是无法获取到 EXIF 信息的。如果对 PNG 图片使用 exif_read_data() 就会报出警告。而对于 JPG 来说,就会返回完整的全部的 EXIF 内容。这里我们只截取了一部分,本身的内容非常多,不只是宽、高、类型、压缩比率之类的,如果是手机拍摄的还能看到手机厂商、地理位置、快门参数、光圈参数等,当然,这个也和你使用的相机有很大的关系,有的厂家可能就会少一些数据。这个大家可以自己拍张照然后使用这个函数来自己查看一下。

另外,还有一个别名函数 read_exif_data() ,与 exif_read_data() 的功能是类似的,就是它的一个别名,并且在 PHP7 以后就已经标记为过时的语法了。大家可以了解一下。

var_dump(read_exif_data($jpg));
// PHP Deprecated: Function read_exif_data() is deprecated in /Users/zhangyue/MyDoc/博客文章/dev-blog/php/202011/source/11.使用PHP获取图像文件的EXIF信息.php on line 17

// Deprecated: Function read_exif_data() is deprecated in /Users/zhangyue/MyDoc/博客文章/dev-blog/php/202011/source/11.使用PHP获取图像文件的EXIF信息.php on line 17
// array(8) {
// [“FileName”]=>
// string(5) “2.jpg”
// [“FileDateTime”]=>
// int(1605061174)
// [“FileSize”]=>
// ……
// ……登录后复制获取指定索引的头名称

索引头对应的就是 EXIF 中的字段名称,我们可以查看当前所有支持的索引头信息,内容非常多。也可以根据索引头获得属性名称,然后再到 EXIF 中查找对应的属性信息。

echo “256: ” . exif_tagname(256) . PHP_EOL;
// 256: ImageWidth
for ($id = 1; $id <= 65535; $id++) {
if (exif_tagname($id) != "") {
echo $id . ; ( ; . exif_tagname($id) . ; );, PHP_EOL;
}
}
// 11 ( ACDComment )
// 254 ( NewSubFile )
// 255 ( SubFile )
// 256 ( ImageWidth )
// 257 ( ImageLength )
// 258 ( BitsPerSample )
// 259 ( Compression )
// ……
// ……
// ……登录后复制读取 JPG 文件中嵌入的缩略图

可能很多人不知道吧,EXIF 中是可以保存一个缩略图的。而且大家的手机拍出来的相片基本都会有这个缩略图存在。Windows 系统中如果图片有缩略图的话也会直接用 EXIF 中的缩略图,如果没有的话,就会自动在目录中生成一个 Thumbs.db 文件,也就是一个缩略图的数据库。

var_dump(exif_thumbnail(;../img/3.jpeg;));

file_put_contents(;../img/3-thumbnail.jpeg;, exif_thumbnail(;../img/3.jpeg;));登录后复制

在 PHP 中可以通过 exif_thumbnail() 这个函数直接获取 JPG 文件中 EXIF 里面保存的缩略图信息。在测试代码中我们获取到后再将它保存为正式的图片,大家就可以看到缩略图的真实样子了。并且我们使用 exif_read_data() 来读取这个文件的话,也能看到缩略图保存的信息。

var_dump(exif_read_data(;../img/3.jpeg;));
// array(56) {
// ……
// ……
// ……
// [“Make”]=>
// string(6) “Xiaomi”
// [“THUMBNAIL”]=>
// array(9) {
// [“JPEGInterchangeFormat”]=>
// int(5504)
// [“Orientation”]=>
// int(6)
// [“JPEGInterchangeFormatLength”]=>
// int(14369)
// [“Compression”]=>
// int(6)
// [“ResolutionUnit”]=>
// int(2)
// [“XResolution”]=>
// string(4) “72/1”
// [“YResolution”]=>
// string(4) “72/1”
// [“ExifImageLength”]=>
// int(240)
// [“ExifImageWidth”]=>
// int(320)
// }
// [“UndefinedTag:0x9AAA”]=>
// string(4480) “1y�L�=w%�s_�&��v��oJ��$Gdz|d�9n�
// ……
// ……登录后复制总结

对于图片的 EXIF 有了一个基本的了解了吧。今天学习的需要注意的几点是:一是 EXIF 只有 JPG 、 TIFF 这类的图片格式上才有,二是它们是可修改的,三是这玩意里面竟然还能保存一张缩略图。果然,学习就是个无底洞,一不小心又开了眼界了。加油吧,少年们!

测试代码:https://github.com/zhangyue0503/dev-blog/blob/master/php/202011/source/11.使用PHP获取图像文件的EXIF信息.php

PHP数据库学习之怎样使用PDO执行SQL语句?

原创2021-10-28 12:05:322490 + php学习QQ群(点击入群)在之前的文章中给大家带来了《PHP数据库学习之怎样使用PDO连接数据库?》,其中给大家详细的介绍了在PHP中怎样通过PDO来连接数据库,本篇文章我们继续来看一下PHP中怎样使用PDO执行SQL语句。希望对大家有帮助!

浅谈怎么利用PHP读取到图片的EXIF信息(附代码)

千万级数据并发如何处理?进入学习

在之前的文章中我们已经学习到了PHP怎样通过PDO来连接到数据库,连接到数据库那就得执行SQL语句。在 PDO 中,我们可以使用三种方式来执行 SQL 语句,分别是 exec() 方法,query() 方法,以及预处理语句 prepare() 和 execute() 方法。那接下来我们一起来看一下吧。

exec() 方法

在我们执行 INSERT、UPDATE 和 DELETE 等这些不需要返回结果集的SQL语句的时候,我们就可以使用PDO对象中的 exec() 方法,使用这种方法成功执行之后,返回的结果是受到影响的行数,

exec() 方法的语法格式如下:

PDO::exec(string $sql)登录后复制

要注意的是:

  • $sql 为要执行的 SQL 语句。

  • exec() 方法不会从 SELECT 查询语句中获取相应的结果。

那接下来我们通过实例尝试向数据库中加入一条数据,示例如下:

exec($sql);
if($res) echo '成功添加 '.$res.' 条数据!';
}catch(PDOException $e){
echo '数据库连接失败:'.$e -> getMessage();
}
?>登录后复制

输出结果:

浅谈怎么利用PHP读取到图片的EXIF信息(附代码)

由上述示例可以看出,我们通过exec()方法成功的向数据库中加入了一条数据,并且返回的结果是收到影响的行数。想要返回一个对象的话就可以通过query() 方法,接下来我们看另一种执行SQL语句的方式:query() 方法。

query() 方法

在上述事例中通过exec()方法能够返回这些不需要返回结果集的语句信息,当执行需要返回结果集的 SELECT 查询语句时,我们就需要通过query()语句。通过该方法执行成功的话,反悔的家国是一个PDOStatement 对象。

如果使用了query() 方法,并想了解获取的数据行总数,可以使用 PDOStatement 对象中的 rowCount() 方法获取。

query()方法的语法格式如下:

PDO::query(string $sql)
PDO::query(string $sql, int $PDO::FETCH_COLUMN, int $colno)
PDO::query(string $sql, int $PDO::FETCH_CLASS, string $classname, array $ctorargs)
PDO::query(string $sql, int $PDO::FETCH_INTO, object $object)登录后复制

其中需要注意的是:

$sql 为要执行的 SQL 语句;其余的参数用来为语句设置默认的获取模式,相当于调用结果对象 PDOStatement::setFetchMode() 方法。

那接下来我们通过query()方法来查询我们前面添加的那条数据,示例如下:

query($sql,PDO::FETCH_ASSOC);
print_r($res);
}catch(PDOException $e){
echo '数据库连接失败:'.$e -> getMessage();
}
?>登录后复制

输出结果:

浅谈怎么利用PHP读取到图片的EXIF信息(附代码)

其中使用 query() 和 exec() 方法有以下几点需要注意:

  • query() 和 exec() 都可以执行所有的 SQL 语句,只是返回值不同而已;

  • query() 可以实现所有 exec() 的功能;

  • 当把 select 语句应用到 exec() 时,总是返回 0;

  • 如果要看查询的具体结果,可以通过 foreach 语句完成循环输出。

prepare() 和 execute() 方法

当有需要迭代传入不同参数的时候,也就是方同一个查询需要多次执行的时候,使用预处理语句的方式会让实现效率更高,使用预处理语句就需要用到PDO对象中的 prepare() 方法去准备一个将要执行的查询,再使用 PDOStatement 对象中的 execute() 方法来执行。那接下来我们就来看一下prepare() 和 execute() 方法。

prepare() 方法的语法格式如下:

PDO::prepare(string $statement[, array $driver_options = array()])登录后复制

其中需要注意的是:

  • $statement 表示的是必须是对目标数据库有效的 SQL 语句模板;

  • $driver_options 表示为可选参数,是数组类型的可选参数,包含一个或多个键值对,为返回的 PDOStatement 对象设置属性。

execute() 方法的语法格式如下:

PDOStatement::execute([array $input_parameters])登录后复制

其中需要注意的是:

  • 参数 $input_parameters 为一个元素个数和将被执行的 SQL 语句中绑定的参数一样多的数组。

  • SQL 语句模板中可以包含零个或多个参数占位标记,格式可以是命名(:name)或问号(?)的形式,当它执行时将用真实数据取代。

  • 在同一个 SQL 语句里,命名和问号形式不能同时使用,只能选择其中一种参数形式。如果使用命名形式的占位标记,那么标记的命名必须是唯一的。

接下来我们看一下使用命名形式的参数占位符,查询指定的 SQL 语句,示例如下:

prepare($sql);
$sth -> execute([':age'=>11]);
$res1 = $sth -> fetchAll();
$sth -> execute(array(':age'=>14));
$res2 = $sth -> fetchAll();
echo '';
print_r($res1);
print_r($res2);
}catch(PDOException $e){
echo '数据库连接失败:'.$e -> getMessage();
}
?>登录后复制

输出结果:

浅谈怎么利用PHP读取到图片的EXIF信息(附代码)

上述示例是使用命名形式的参数占位符,查询指定的 SQL 语句,接下来我们看一下使用问号形式的参数占位符,查询指定的 SQL 语句。示例如下:

prepare($sql);
$sth -> execute([12,'男']);
$res1 = $sth -> fetchAll();
$sth -> execute(array(11,'女'));
$res2 = $sth -> fetchAll();
echo '';
print_r($res1);
print_r($res2);
}catch(PDOException $e){
echo '数据库连接失败:'.$e -> getMessage();
}
?>登录后复制

输出结果:

浅谈怎么利用PHP读取到图片的EXIF信息(附代码)

由此我们便通过使用问号形式的参数占位符,查询指定的 SQL 语句。

大家如果感兴趣的话,可以点击《PHP视频教程》进行更多关于PHP知识的学习。

以上就是PHP数据库学习之怎样使用PDO执行SQL语句?的详细内容,更多请关注钦钦技术栈其它相关文章!

转载至:php中文网【www.php.cn】

版权声明:本文(即:原文链接:https://www.qin1qin.com/catagory/27220/)内容由互联网用户自发投稿贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 630367839@qq.com 举报,一经查实,本站将立刻删除。

(0)
上一篇 2022-09-29 5:06:56
下一篇 2022-09-29 5:07:43

软件定制开发公司

相关阅读

发表回复

登录后才能评论
通知:禁止投稿所有关于虚拟货币,币圈类相关文章,发现立即永久封锁账户ID!