下面我們舉了二個例子都是利用ord來實例字符ascii判斷以勉出現中文亂碼的問題,這個函數的功能我們可以參考http://www.bKjia.c0m/phper/php/41030.htm 文章,它很好了介紹了此函數的用法。
代碼如下 復制代碼
<?php
//a字符
$str=(pack("a*", "中國"));
echo $str,"=",strlen($str),"字節n";
getascill($str);
//h字符
$str=(pack("h*", "fffe"));
echo $str,"=",strlen($str),"字節n";
getascill($str);
//c字符
$str=(pack("c*", "55","56","57"));
echo $str,"=",strlen($str),"字節n";
getascill($str);
//i字符 短整形 32位 4個字節 64位8個字節
$str=(pack("i", "100"));
echo $str,"=",strlen($str),"字節n";
getascill($str);
//s字符 短整形 2個字節
$str=(pack("s", "100"));
echo $str,"=",strlen($str),"字節n";
getascill($str);
//l字符 長整形 4個字節
$str=(pack("l", "100"));
echo $str,"=",strlen($str),"字節n";
getascill($str);
//f字符 單精度浮點 4個字節
$str=(pack("f", "100"));
echo $str,"=",strlen($str),"字節n";
getascill($str);
//d字符 雙精度浮點 8個字節
$str=(pack("d", "100"));
echo $str,"=",strlen($str),"字節n";
getascill($str);
function getascill($str)
{
$arr=str_split($str);
foreach ($arr as $v)
{
echo $v,"=",ord($v),"n";
}
echo "=============rnrn";
}
?>
更多詳細內容請查看:http://www.bKjia.c0m/phper/php-function/php-ord.htm
實例二
代碼如下 復制代碼<?
/*
@ 另一種方法,使用ord()函數:
@ 適用於 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)不會顯示出什麼,但是他是一個字符。當漢字被截斷時,根據編碼規則他總是要把後邊的其他字符拉過來一起作為漢字解釋,這就是出現亂碼的原因。
?>