php chr() ord()中文截取亂碼問題解決方法
更新時間:2008年09月08日 11:03:58 作者:
今天看到chr() ord()中文截取亂碼問題這個例子,覺得相當?shù)牟诲e,拿出來和大家分享下,有興趣的朋友可以去試下,看看怎么樣.
復(fù)制代碼 代碼如下:
<?php
$lenth = 19;
$str = "怎么將新聞的很長的標題只顯示前面一些字,后面用.....來代替?";
echo strlen($str)<=$lenth ? $str : (substr($str,0,$lenth).chr(0)."....");
?>
復(fù)制代碼 代碼如下:
<?
/*
@ 另一種方法,使用ord()函數(shù):
@ 適用于 gb2312 編碼:
*/
$str = "怎么將新聞的很長的標題只顯示前面一些字,后面用.....來代替?";
function gb2312_substr($str, $limit) {
$restr ='';
for($i=0;$i< $limit-3;$i++) {
$restr .= ord($str[$i])>127 ? $str[$i].$str[++$i] : $str[$i];
}
return $restr;
}
/*
@ 以下僅適用于 utf-8 編碼;
*/
function utf8_substr($str, $limit) {
$restr = '';
for($i=0;$i< $limit-3;$i++) {
$restr .= ord($str[$i])>127 ? $str[$i].$str[++$i].$str[++$i] : $str[$i];
}
return $restr;
}
//解釋下上面第一個:chr(0)不是null,null是什么都沒有,而chr(0)的值是0。表示成16進制是0x00,表示成二進制是00000000雖然chr(0)不會顯示出什么,但是他是一個字符。雖然chr(0)不會顯示出什么,但是他是一個字符。當漢字被截斷時,根據(jù)編碼規(guī)則他總是要把后邊的其他字符拉過來一起作為漢字解釋,這就是出現(xiàn)亂碼的原因。
?>
相關(guān)文章
PHP+JS+rsa數(shù)據(jù)加密傳輸實現(xiàn)代碼
PHP+JS+rsa數(shù)據(jù)加密傳輸實現(xiàn)代碼,需要的朋友可以參考下。2011-03-03php采用file_get_contents代替使用curl實例
這篇文章主要介紹了php采用file_get_contents代替使用curl的方法,實例講述了file_get_contents模擬curl的post方法,對于服務(wù)器不支持curl的情況來說有一定的借鑒價值,需要的朋友可以參考下2014-11-11