获取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协议

DependencyInjection(DI)inPHPenhancescodeflexibilityandtestabilitybydecouplingdependencycreationfromusage.ToimplementDIeffectively:1)UseDIcontainersjudiciouslytoavoidover-engineering.2)Avoidconstructoroverloadbylimitingdependenciestothreeorfour.3)Adhe

到Improveyourphpwebsite的實力,UsEthestertate:1)emplastOpCodeCachingWithOpcachetCachetOspeedUpScriptInterpretation.2)優化的atabasequesquesquesquelies berselectingOnlynlynnellynnessaryfields.3)usecachingsystemssslikeremememememcachedisemcachedtoredtoredtoredsatabaseloadch.4)

是的,ItispossibletosendMassemailswithp.1)uselibrarieslikeLikePhpMailerorSwiftMailerForeffitedEmailsending.2)enasledeLaysBetenemailstoavoidSpamflagssspamflags.3))

DependencyInjection(DI)inPHPisadesignpatternthatachievesInversionofControl(IoC)byallowingdependenciestobeinjectedintoclasses,enhancingmodularity,testability,andflexibility.DIdecouplesclassesfromspecificimplementations,makingcodemoremanageableandadapt

使用PHP發送電子郵件的最佳方法包括:1.使用PHP的mail()函數進行基本發送;2.使用PHPMailer庫發送更複雜的HTML郵件;3.使用SendGrid等事務性郵件服務提高可靠性和分析能力。通過這些方法,可以確保郵件不僅到達收件箱,還能吸引收件人。

計算PHP多維數組的元素總數可以使用遞歸或迭代方法。 1.遞歸方法通過遍歷數組並遞歸處理嵌套數組來計數。 2.迭代方法使用棧來模擬遞歸,避免深度問題。 3.array_walk_recursive函數也能實現,但需手動計數。

在PHP中,do-while循環的特點是保證循環體至少執行一次,然後再根據條件決定是否繼續循環。 1)它在條件檢查之前執行循環體,適合需要確保操作至少執行一次的場景,如用戶輸入驗證和菜單系統。 2)然而,do-while循環的語法可能導致新手困惑,且可能增加不必要的性能開銷。

在PHP中高效地哈希字符串可以使用以下方法:1.使用md5函數進行快速哈希,但不適合密碼存儲。 2.使用sha256函數提高安全性。 3.使用password_hash函數處理密碼,提供最高安全性和便捷性。


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

ZendStudio 13.5.1 Mac
強大的PHP整合開發環境

SecLists
SecLists是最終安全測試人員的伙伴。它是一個包含各種類型清單的集合,這些清單在安全評估過程中經常使用,而且都在一個地方。 SecLists透過方便地提供安全測試人員可能需要的所有列表,幫助提高安全測試的效率和生產力。清單類型包括使用者名稱、密碼、URL、模糊測試有效載荷、敏感資料模式、Web shell等等。測試人員只需將此儲存庫拉到新的測試機上,他就可以存取所需的每種類型的清單。

Atom編輯器mac版下載
最受歡迎的的開源編輯器

MinGW - Minimalist GNU for Windows
這個專案正在遷移到osdn.net/projects/mingw的過程中,你可以繼續在那裡關注我們。 MinGW:GNU編譯器集合(GCC)的本機Windows移植版本,可自由分發的導入函式庫和用於建置本機Windows應用程式的頭檔;包括對MSVC執行時間的擴展,以支援C99功能。 MinGW的所有軟體都可以在64位元Windows平台上運作。

MantisBT
Mantis是一個易於部署的基於Web的缺陷追蹤工具,用於幫助產品缺陷追蹤。它需要PHP、MySQL和一個Web伺服器。請查看我們的演示和託管服務。