將一個(gè)短信接口代碼從apache遷移到nginx+php-fpm后,發(fā)現(xiàn)無(wú)法發(fā)出短信了,查看php日志,
[25-Sep-2014 20:15:21] WARNING: [pool www] child 9617 said into stderr: “NOTICE: PHP message: PHP Fatal error: Call to undefined function mb_convert_encoding() in /data/htdocs/xx.php on line 13″
發(fā)現(xiàn)函數(shù)mb_convert_encoding沒(méi)定義,看著像某個(gè)模塊沒(méi)裝,google了把,要裝個(gè)mbstring擴(kuò)展,之前都是一下裝好多擴(kuò)展(雖然不知道這個(gè)擴(kuò)展是干啥的,按照網(wǎng)絡(luò)文檔來(lái)),現(xiàn)在是要應(yīng)用需要哪個(gè)裝哪個(gè),逼格略有提高(至少這樣能讓我知道哪個(gè)模塊是干啥的)。
mb-convert-encoding
string mb_convert_encoding ( string $str , string $to_encoding [, mixed $from_encoding = mb_internal_encoding() ] )
將 string 類型 str 的字符編碼從可選的 from_encoding 轉(zhuǎn)換到 to_encoding。
官網(wǎng)文檔 http://php.net/manual/zh/function.mb-convert-encoding.php 需要安裝mbstring擴(kuò)展庫(kù),如果已經(jīng)編譯好的php可以這樣熱編譯下
代碼如下:
cd /tmp/php-5.3.28/ext/mbstring/
usr/local/services/php/bin/phpize
./configure --with-php-config=/usr/local/services/php/bin/php-config
make && make install
vim /usr/local/services/php/etc/php.ini
extension="/usr/local/services/php/lib/php/extensions/no-debug-non-zts-20090626/mbstring.so";
iconv
string iconv ( string in_charset, string out_charset, string str )
iconv函數(shù)庫(kù)能夠完成各種字符集間的轉(zhuǎn)換
注意:第二個(gè)參數(shù),除了可以指定要轉(zhuǎn)化到的編碼以外,還可以增加兩個(gè)后綴://TRANSLIT 和 //IGNORE,其中 //TRANSLIT 會(huì)自動(dòng)將不能直接轉(zhuǎn)化的字符變成一個(gè)或多個(gè)近似的字符,//IGNORE 會(huì)忽略掉不能轉(zhuǎn)化的字符,而默認(rèn)效果是從第一個(gè)非法字符截?cái)唷?/P>
Returns the converted string or FALSE on failu
官網(wǎng)地址 http://php.net/manual/zh/book.iconv.php
已經(jīng)安裝好php的,同樣也可以使用上面的方法安裝iconv模塊
mb_convert_encoding例子
mb_convert_encoding這個(gè)函數(shù)是用來(lái)轉(zhuǎn)換編碼的。英文一般不會(huì)存在編碼問(wèn)題,只有中文數(shù)據(jù)才會(huì)有這個(gè)問(wèn)題。比如你用Zend Studio或Editplus寫程序時(shí),用的是gbk編碼,如果數(shù)據(jù)需要入數(shù)據(jù)庫(kù),而數(shù)據(jù)庫(kù)的編碼為utf8時(shí),這時(shí)就要把數(shù)據(jù)進(jìn)行編碼轉(zhuǎn)換,不然進(jìn)到數(shù)據(jù)庫(kù)就會(huì)變成亂碼
做一個(gè)GBK To UTF-8
代碼如下:
<?php
header(“content-Type: text/html; charset=Utf-8″);
echo mb_convert_encoding(“???S我的友仔”, “UTF-8″, “GBK”);
?>
再來(lái)個(gè)GB2312 To Big5
代碼如下:
<?php
header(“content-Type: text/html; charset=big5″);
echo mb_convert_encoding(“你是我的朋友”, “big5″, “GB2312″);
?>
mb_strtolower() – 使字符串小寫
mb_strtoupper() – 使字符串大寫
strtolower() – 將字符串轉(zhuǎn)化為小寫
strtoupper() – 將字符串轉(zhuǎn)化為大寫
ucfirst() – 將字符串的首字母轉(zhuǎn)換為大寫
ucwords() – 將字符串中每個(gè)單詞的首字母轉(zhuǎn)換為大寫
iconv例子
把gb2312置換成utf-8:
代碼如下:
$text=iconv("GB2312","UTF-8",$text);
在用$text=iconv(“UTF-8″,”GB2312″,$text)過(guò)程中,如果遇到一些特別字符時(shí),如:”—”,英文名中的”.”等等字符,轉(zhuǎn)換就斷掉了。這些字符后的文字都沒(méi)法繼續(xù)轉(zhuǎn)換了。
針對(duì)這的問(wèn)題,可以用如下代碼實(shí)現(xiàn):
代碼如下:
$text=iconv("UTF-8","GBK",$text);
你沒(méi)有看錯(cuò),就這么簡(jiǎn)單,不使用gb2312,而寫成GBK,就可以了。
還有一種方法,第二個(gè)參數(shù),加上//IGNORE,忽略錯(cuò)誤,如下:
代碼如下:
iconv("UTF-8","GB2312//IGNORE",$data);
一般情況下用 iconv,只有當(dāng)遇到無(wú)法確定原編碼是何種編碼,或者iconv轉(zhuǎn)化后無(wú)法正常顯示時(shí)才用mb_convert_encoding 函數(shù)。
代碼如下:
$content = iconv("GBK", "UTF-8″, $content);
$content = mb_convert_encoding($content, "UTF-8″, "GBK");
更多信息請(qǐng)查看IT技術(shù)專欄