图片是以二进制的形式存入数据库的,不用while循环还能在浏览器上输出第一张,用了之后,输出的是乱码,是不是在输出图片之前不能有任何输出??
查了很多,都没有效果,求高手指点
<?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];//用一条语句能输出一张图片
?> <table width="80%" height="80%" border="1"> <?php
while($result=mysql_fetch_array($select)){
//echo stripslashes($result['photo']); //stripslashes()去除反斜杠
?>

   <tr height="400">
      <td> <?php echo $result['photo']?> </td>
   </tr>

<?php
}
?> </table> <?php 
//关闭文件
fclose($fp);
?>

解决方案 »

  1.   

    还是那句话,Content-Type:image/jpeg 声明响应内容为字节流。而你的代码还输出了字符流,自然导致浏览器无法准确识别和转换。
    想在浏览器端显示多个图片,就必须遵循HTML格式标准。img标签的src属性支持file:// http:// data:// 等各种协议,但就是不能直接填入图片字节流。还是希望你别在这棵树上吊着。你用这种没有意义,不合常理的项目练手,不仅不会有收获,反而会让你越学越迷糊
      

  2.   

    先前我对流的理解也有问题,你有空可以看看正确的解释:
    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协议