搞定ThinkPHP驗證碼不顯示的問題

下面由thinkphp框架教程欄目給大家介紹thinkphp驗證碼不顯示的解決方案,希望對需要的朋友有所幫助!

搞定ThinkPHP驗證碼不顯示的問題

今天遇到一個很奇怪的bug,就是我寫了一個PHP程序本地運行正常,但是發(fā)布到甲方的服務器上出現(xiàn)無法顯示驗證碼的BUG。

搞定ThinkPHP驗證碼不顯示的問題

具體表現(xiàn)就是chorme瀏覽器上顯示一個裂了的圖片小圖標,右鍵點擊該圖片在新窗口打開,仍然是一個裂了的小圖片,并非報錯信息(開啟xdebug擴展和php報錯的情況下),如果是這樣那么就說明驗證碼URL路由和業(yè)務邏輯代碼沒問題,是生成驗證碼的環(huán)節(jié)出問題了,我的Debug思路是這樣的:

1.檢查GD庫是否安裝正確,linux推薦使用yum或者apt或者pecl等方式安裝,windows推薦使用phpstudy這個集成環(huán)境,他集成好了常用擴展,只需鼠標右鍵開啟即可。(適用于驗證碼圖片在新窗口打開的時候顯示了報錯信息以及一亂碼的情況下,如果有報錯信息,請根據(jù)報錯信息進行debug)

立即學習PHP免費學習筆記(深入)”;

搞定ThinkPHP驗證碼不顯示的問題

2.檢查驗證碼所調用的字體是否缺失。有部分驗證碼組件調用的字體在目標計算機上并未安裝,這個需要分析驗證碼模塊的源碼觀察。我用的是thinkphp官方的think-captcha,在vendortopthinkthink-captchasrc可以找到他的源碼,在vendortopthinkthink-captchaassets這里可以看到這款驗證碼插件是自帶了字體的,所以ThinkPHP的驗證碼基本上可以不用考慮字體問題,如果是別的驗證碼插件,那么還是要檢查一下這個地方的。

3.把有bug的驗證碼圖片下載下來,以及本地測試正常的驗證碼圖片下載下來,使用記事本查看并且對比。

搞定ThinkPHP驗證碼不顯示的問題

上圖是本地環(huán)境的驗證碼圖片的記事本,我們使用更專業(yè)的16進制編輯器來分析一下文件差別。

搞定ThinkPHP驗證碼不顯示的問題

如圖所示,我們發(fā)現(xiàn)bad這個壞文件除了前面多了EF BB BF等數(shù)字以外,其他內容一模一樣,說明是PHP在渲染圖片的時候多渲染了這些文字,至于原因我猜測可能是服務器上沒有專業(yè)的代碼編輯器,因此運維人員使用普通的Windows記事本修改了php代碼導致多了這個bom頭部。

如果是第三種原因,解決方法有兩個,一個是在驗證碼的imagepng輸出圖片代碼調用之前用ob_clean清除php的輸出緩沖區(qū)。還有就是使用一些工具批量對代碼的bom進行去除。

搞定ThinkPHP驗證碼不顯示的問題

我這里使用的是ob_clean,在think-captcha的主文件Captcha.php的第203行之前加上ob_clean(),這樣一勞永逸。如果對性能和穩(wěn)定性有嚴苛要求,建議還是用工具批量去除bom比較保險。同時也建議大家隨時在服務器上裝一個editplus等專業(yè)的代碼編輯器。不要用Windows的記事本修改代碼。

? 版權聲明
THE END
喜歡就支持一下吧
點贊5 分享