談PHP的GD函數(shù)imagettftext()要注意默認字符編碼_PHP教程
推薦:淺析php分頁類 只用傳入總頁數(shù)PHP培訓(xùn)有一段時間了,消失也有一段時間了,特地封裝一個分頁類上傳上來,自己寫的,高手指點,新手學(xué)習(xí),莫笑話!呵呵 配合CSS樣式會好看點. CODE: DIV.page { PADDING-RIGHT: 3px; PADDING-LEFT: 3px; PADDING-BOTTOM: 3px; MARGIN: 3px; PADDING-TOP: 3px
這陣子在開發(fā)一個小功能,就是類似論壇個性簽名的東西,根據(jù)會員信息自動生成一張圖片上面還有文字的那種。圖片的拼合用imagecopy()和imagecopyresampled()等函數(shù)就可以搞定,到了畫文字的時候遇到了一個難題。
文字的模板是保存在一個文本文件中,程序先讀取這個文件然后用數(shù)據(jù)替換掉里面的變量,再使用imagettftext()函數(shù)畫到圖片上,不幸的是畫出來的圖片居然是亂碼@_@@_@……于是上Google搜索相關(guān)的問題,發(fā)現(xiàn)大部分人都是在說imagettftext()函數(shù)中傳遞的字串要UTF-8編碼,而PHP官方手冊中也明確寫著“UTF-8編碼的字串可以直接傳遞”,可問題是模板文件的編碼本來就是UTF-8的,這就有點莫名其妙了。無奈之下我用EmEditor打開原來的模板文件,嘗試轉(zhuǎn)換成不同的編碼后和GD輸出的亂碼做對比,結(jié)果發(fā)現(xiàn)轉(zhuǎn)換到EUC-JP編碼的時候居然和GD輸出的亂碼吻合了……也就是說,這里服務(wù)器上GD的默認編碼是EUC-JP,而那是一種日文編碼。查找了一下php.ini的設(shè)置沒有發(fā)現(xiàn)相關(guān)選項,于是又一個問題來了,這個默認編碼是在哪里設(shè)置的呢?還是史文大哥牛,發(fā)現(xiàn)了PHP編譯參數(shù)里面有一個“–enable-gd-jis-conv”的參數(shù)十分可疑,Goo一下果然發(fā)現(xiàn)了很多亂碼問題與這個編譯參數(shù)有關(guān)……官方給出的參數(shù)說明是“GD: Enable JIS-mapped Japanese font support.”,也就是讓GD支持日文編碼的字庫(可惡,為什么沒有支持中文編碼字庫的編譯選項……PHP也國籍歧視么= =b),說白了開啟了這個選項的話GD就會把TTF字庫中大于127的部分(即不屬于標準拉丁文字庫的部分)按照日文JIS的順序來映射,那么用來映射中文字體的時候自然就變成亂碼了。二話不說,去掉這個選項重新編譯,問題解決。去掉這個選項之后,imagettftext()的默認編碼就變成了UTF-8,就可以正常顯示中文了~
分享:解答網(wǎng)頁中PHP腳本中include文件報錯的方法經(jīng)常當php頁面中利用include, require, require_once包含了一些其他位置的頁面時,會出現(xiàn)錯誤,比如沒有發(fā)現(xiàn)次頁面,或者權(quán)限不允許等,可以根據(jù)以下方法來排除 1. 出現(xiàn)
- 相關(guān)鏈接:
- 教程說明:
PHP教程-談PHP的GD函數(shù)imagettftext()要注意默認字符編碼
。