<? class qswhGBK{ var $qswhData; function qswhGBK($filename="qswhGBK.php"){ $this->qswhData=file($filename); } function gb2u($gb,$callback=""){ /******(qiushuiwuhen 2002-8-15)******/ $ret=""; for($i=0;$i<strlen($gb);$i++){ if(($p=ord(substr($gb,$i,1)))>127){
header("Content-type: text/vnd.wap.wml; charset=\"utf-8\"");
echo "<?xml version=\"1.0\" encoding=\"gb2312\"?>
<!DOCTYPE wml PUBLIC \"-//WAPFORUM//DTD WML 1.3//EN\" \"http://www.wapforum.org/DTD/wml13.dtd\" >
<wml xml:lang=\"zh\">
<head>
<meta http-equiv=\"Cache-Control\" content=\"no-cache\"/>
</head>帮忙看一下,是不是这样错了?现在按照我这样的改法,页面进不去了~编码的位置究竟应当怎么样呢?
echo "<?xml version=\"1.0\" encoding=\"utf-8\"?><wml xml:lang=\"zh\">改成
<wml xml:lang=\"zh-cn\">试一试
用winwap测试一下
class qswhGBK{
var $qswhData;
function qswhGBK($filename="qswhGBK.php"){
$this->qswhData=file($filename);
}
function gb2u($gb,$callback=""){
/******(qiushuiwuhen 2002-8-15)******/
$ret="";
for($i=0;$i<strlen($gb);$i++){
if(($p=ord(substr($gb,$i,1)))>127){
$q=ord(substr($gb,++$i,1));
$q=($q-($q>128?65:64))*4;
$q=substr($this->qswhData[$p-128],$q,4);
}
else
$q=dechex($p);
if(empty($callback))
$ret.=$q;
else {
$arr=array("htmlHex","htmlDec","escape","u2utf8");
if(is_integer($callback)){
if($callback>count($arr))die("Invalid Function");
$ret.=$this->$arr[$callback-1]($q);
}else
$ret.=$callback($q);
}
}
return $ret;
}
function htmlHex($str){
return "&#x".$str.";";
}
function htmlDec($str){
return "&#".hexdec($str).";";
}
function escape($str){
return hexdec($str)<256?chr(hexdec($str)):"%u".$str;
}
function u2utf8($str){
/******(qiushuiwuhen 2002-8-15)******/
$sp="!'()*-.0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ_abcdefghijklmnopqrstuvwxyz~";
$dec=hexdec($str);
$bin=decbin($dec);
$len=strlen($bin);
$arr=array("c0","e0","f0");
if($dec>0x7f){
$ret="";
for($i=$len,$j=-1;$i>=0;$i-=6,$j++){
if($i>6)
$ret="%".dechex(0x80+bindec(substr($bin,$i-6,6))).$ret;
else
$ret="%".dechex(hexdec($arr[$j])+bindec(substr($bin,0,6-$i))).$ret;
}
}else{
if(strpos($sp,chr($dec)))
$ret=chr($dec);
else
$ret="%".strtolower($str);
}
return $ret;
}
}
?>
有一个比较完整的字符编码转换包。
#iconv -f GB2312 -t UTF-8 文件名 > 另存文件名
------------
http://ouk.cn/utf8/ 中间的空隙就是另存为UTF-8编码产生的!````这个的原因大概不在另存为上面,呵呵,至少我用另存为从没发生过问题。注意:对于纯ansii字符组成的文件另存为utf-8,editplus是什么也不会去做的。只有用notepad
echo "<?xml version=\"1.0\" encoding=\"gb2312\"?>
这里明显就是错误的了