>  기사  >  백엔드 개발  >  获取MySQL中二进制存取的图片,只好输出第一张,不能循环输出?

获取MySQL中二进制存取的图片,只好输出第一张,不能循环输出?

WBOY
WBOY원래의
2016-06-13 10:57:33852검색

获取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协议
성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.