此文可能比较繁琐,有更好的方法,但是出于教程目的,这也是我得出的"“最佳实践”的路线。
今天,我们将讨论一个似乎每个人都有些困惑的话题……在MySQL中存储BLOB图像,然后使用PHP再次显示它们。尽管始终建议不要这样做,但我先展示一些演示代码,说明如何实现此目标,并讨论为什么/为什么不这样做。然后,讨论一些替代方案,以及为什么与直接将图像直接存储到数据库相比。
因此BLOB或“Binary Large Objects”是数据库中用于存储原始二进制数据的字段。这些数据可能代表图片,文件或二进制格式的文本。
由于这些类型的对象相当大(甚至可能是千兆字节大小),因此该字段旨在容纳大量信息。我们如何在PHP中使用这些字段来插入个人资料图片?
1、我们必须将图像读取为二进制。
2、我们必须准备将其插入数据库(转义)。
3、我们使用典型的SQL将其插入数据库中
对于我们的示例,我们将使用三步过程...
1、设置文档的内容类型以使其与图片类型相匹配(对于jpg图片,图像/ jpeg)
2、在数据库中找到图像并将其拔出
3、显示它
(今日头条代码块显示就这个样子,我也没办法。)
在这里,我们打开文件进行读取并将图像读取到变量中。对该fread()的调用正在读取图像的字节,因此我