接到一个需求,审核页面显示客户端上传的图片。通常用Img标签从 Web 服务器上获取图片,并把它插入到页面中,但是需要确保图片与相关的网页在同一站点,否则浏览器找不到图像,会显示损坏的链接图标,解决方法如下:
if (RUN_ENVIRONMENT == 'ONLINE'){ define('ImgPath', '/Img/'); }else{ define('ImgPath', '/www/upfile/Img/'); }
/*获取Get传参*/ $sFileName = $this->GetVal('imgname'); if (empty($sFileName)) { exit(); } /*获取文件*/ $sFileName = ImgPath . $sFileName; $sFileType = substr(strrchr($sFileName, '.'), 1); /*注意文件后缀和MIME类型的区别*/ if ($sFileType == 'jpg') { $sFileType = 'jpeg'; } /*判断文件是否存在*/ if (file_exists($sFileName)) { $sFileRes = file_get_contents($sFileName); header("Content-type: image/$sFileType"); echo $sFileRes; } else { exit(); }
通常会用 id 划分文件夹,最好对文件名做个校验,防止任意文件读取漏洞。
//图片路径 $aResult['picnum'] = 0; if($aResult['pic'] != '') { $aBlockPicArr = explode(',', $aResult[0]['blockpic']); foreach($aBlockPicArr as $key => $pic) { //因为对方是windows服务器,所以我转换了反斜杠 $aResult['pic'.($key+1)] = "showImg.php?imgname=".str_replace('\\', '/', $pic); } $aResult['picnum'] = count($aBlockPicArr); }
<div class="left"> <label for="">图片展示:</label> <?php if($aReturn['picnum'] > 0) { for($i = 1; $i <= $aReturn['picnum']; $i++) { ?> <img style="max-width:1000px;cursor:pointer" src="<? echo $aReturn['pic'.$i]; ?>" onclick="window.open('<? echo $aReturn['pic'.$i]; ?>')"> <?php }} ?> </div>
这样图片就打印出来了。