获取MySQL中二进制存取的图片,只能输出第一张,不能循环输出??
图片是以二进制的形式存入数据库的,不用while循环还能在浏览器上输出第一张,用了之后,输出的是乱码,是不是在输出图片之前不能有任何输出??
查了很多,都没有效果,求高手指点
- PHP code
<!-- Code highlighting produced by Actipro CodeHighlighter (freeware) http://www.CodeHighlighter.com/ --> <?php require_once("conn.php"); $cover=$_POST['cover']; if($_POST['sub']){ header("Content-Type:image/jpeg",true); //以只读的方式打开二进制文件 $fp=fopen($cover,"rb"); $image=addslashes(fread($fp,filesize($cover))); $sql1="insert into phototest (id,photo) values('','$image')"; $insert=mysql_query($sql1,$conn); $sql2="select * from phototest"; $select=mysql_query($sql2,$conn); //$result=mysql_fetch_array($select); echo $result[1];//用一条语句能输出一张图片 ?>
------解决方案--------------------
还是那句话,Content-Type:image/jpeg 声明响应内容为字节流。而你的代码还输出了字符流,自然导致浏览器无法准确识别和转换。
想在浏览器端显示多个图片,就必须遵循HTML格式标准。img标签的src属性支持file:// http:// data:// 等各种协议,但就是不能直接填入图片字节流。
还是希望你别在这棵树上吊着。你用这种没有意义,不合常理的项目练手,不仅不会有收获,反而会让你越学越迷糊
------解决方案--------------------
先前我对流的理解也有问题,你有空可以看看正确的解释:
http://zh.wikipedia.org/zh/MIME Content-type所声明的Mime类型含义
如果content-type为image/jpeg 那么后面的响应内容都只能被理解为是一张jpeg格式的图片。
但若响应内容为text/html,浏览器会当做HTML文档来解析,HTML的标签各有其含义,img标签会被用做展示图片,而src属性则规定图片从哪里加载。
http:// 后跟url链接 规定从服务器上下载,这将另外发起一个请求
file:// 后跟文件地址 规定从本地文件系统上读取,这只能读取本地文件
data:// 后跟有特殊格式的文本 参见rfc2397协议

aphpdepentioncontiveContainerIsatoolThatManagesClassDeptions,增强codemodocultion,可验证性和Maintainability.itactsasaceCentralHubForeatingingIndections,因此reducingTightCightTightCoupOulplingIndeSingantInting。

选择DependencyInjection(DI)用于大型应用,ServiceLocator适合小型项目或原型。1)DI通过构造函数注入依赖,提高代码的测试性和模块化。2)ServiceLocator通过中心注册获取服务,方便但可能导致代码耦合度增加。

phpapplicationscanbeoptimizedForsPeedAndeffificeby:1)启用cacheInphp.ini,2)使用preparedStatatementSwithPdoforDatabasequesies,3)3)替换loopswitharray_filtaray_filteraray_maparray_mapfordataprocrocessing,4)conformentnginxasaseproxy,5)

phpemailvalidation invoLvesthreesteps:1)格式化进行regulareXpressecthemailFormat; 2)dnsvalidationtoshethedomainhasavalidmxrecord; 3)

tomakephpapplicationsfaster,关注台词:1)useopcodeCachingLikeLikeLikeLikeLikePachetoStorePreciledScompiledScriptbyTecode.2)MinimimiedAtabaseSqueriSegrieSqueriSegeriSybysequeryCachingandeffeftExting.3)Leveragephp7 leveragephp7 leveragephp7 leveragephpphp7功能forbettercodeefficy.4)

到ImprovephPapplicationspeed,关注台词:1)启用opcodeCachingwithapCutoredUcescriptexecutiontime.2)实现databasequerycachingusingpdotominiminimizedatabasehits.3)usehttp/2tomultiplexrequlexrequestsandredececonnection.4 limitsclection.4.4

依赖注入(DI)通过显式传递依赖关系,显着提升了PHP代码的可测试性。 1)DI解耦类与具体实现,使测试和维护更灵活。 2)三种类型中,构造函数注入明确表达依赖,保持状态一致。 3)使用DI容器管理复杂依赖,提升代码质量和开发效率。

databasequeryOptimizationinphpinvolVolVOLVESEVERSEVERSTRATEMIESOENHANCEPERANCE.1)SELECTONLYNLYNESSERSAYCOLUMNSTORMONTOUMTOUNSOUDSATATATATATATATATATATRANSFER.3)


热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

Video Face Swap
使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

热工具

EditPlus 中文破解版
体积小,语法高亮,不支持代码提示功能

Dreamweaver CS6
视觉化网页开发工具

Atom编辑器mac版下载
最流行的的开源编辑器

SublimeText3汉化版
中文版,非常好用

适用于 Eclipse 的 SAP NetWeaver 服务器适配器
将Eclipse与SAP NetWeaver应用服务器集成。