php地址栏传中文$_GET上去后乱码,urlencode和urldecode,iconv,base64_encode等办法,整顿根本是罕用的了。飞飞Asp技术乐~园
php地址栏传中文$_GET上去后乱码,urlencode和urldecode用法详解 url编码 语法: string urlencode(string str); 前往值: 字符串 函数品种: 编码解决 例如:
<?php $ChineseName="我的名字,是中文的哦"; $EncodeStr=urlencode($ChineseName); echo "<a href=/cgi/personal.cgi?name=$EncodeStr>我的名字</a>"; ?>
url解码 复原 URL 编码字符串。 语法: string urldecode(string str); 前往值: 字符串 函数品种: 编码解决 例如: 对前面传过来的中文停止解决显示
<?php $DecodeStr=urldecode($_GET['name']);//你能够不用解码都可以,由于阅读器会主动帮你解码 echo $DecodeStr; ?>
对于php用get办法从url上获得的中文乱码成绩
应用$gonghui = iconv("gb2312","UTF-8",$gonghui);另一办法代码
/** * 多字节字符串编码转换函数 * * @param string str 须要停止编码转换的字符串 * @param string to_encoding 指定转换为某种编码,如:gb2312、gbk、utf-8等 * @param mixed from_encoding 混合指定原先字串的编码,如:同时指定 JIS, eucjp-win, sjis-win 混合编码 * @return string string mb_convert_encoding ( string str, string to_encoding [, mixed from_encoding] ) **/ mb_convert_encoding 函数为php内部多字节字符串编码转换函数,可以在有须要的应用处合,简直支持一切编码 。飞飞~Asp技术乐园PHP >= 4.0.6、 5 版本支持 。间接获取 reg.php?gh=某某; //工会登入参 $gonghui = $_GET['gh']; 获得的$gonghui 为gb2312编码 输出到utf-8网页上显示乱码 改成 //工会登入参数 $gonghui = $_GET['gh']; $gonghui = mb_convert_encoding($gonghui, "UTF-8", "gb2312"); 就显示正常了 对整个页面停止转换 该办法适用一切编码环境。这样把前128个字符以外(显示字符)的字符集都用 NCR(Numeric character reference,如“汉字”将转换成“汉字”这种模式)来示意,这样的编码在恣意编码环境下页面都能正 常显示。 在php文件的头部加上上面三行代码:
mb_internal_encoding("gb2312"); // 这里的gb2312是你网站原先的编码 mb_http_output("HTML-ENTITIES"); ob_start('mb_output_handler');
应用mb_convert_encoding 函数需启用PHP 的mbstring (multi-byte string)扩展。 假如没有没有开启php的mbstring扩展,则须要做如下设置,让php支持该扩展。 1、windows 效劳器环境 编辑 php.ini 文件,将; extension=php_mbstring.dll 前面的 ; 去掉,重启网页效劳器。 2、Linux效劳器环境 在编译配置时退出 --enable-mbstring=cn 编译参数,再停止PHP的编译装置。 其它网友的第三个参考办法: //办法一 urldecode $url = 'aaa.php?region='.urldecode("四川省"); <a href="<?php echo $url;?>">aaa </a> //办法二base64_encode <? $test="四川省"; $test1=base64_encode($test); echo '<a href="www.jb51.net?region=$test1">aaa </a>'; ?> 另一页面应用base64_decode解开 base64_decode($region); //办法三让效劳器支持中文 [root@dhcp ~]# locale lang=zh_cn.utf-8 lc_ctype="zh_cn.utf-8" lc_numeric="zh_cn.utf-8" lc_time=c lc_collate=c lc_m lc_messages="zh_cn.utf-8" lc_paper="zh_cn.utf-8" lc_name="zh_cn.utf-8" lc_address="zh_cn.utf-8" lc_telephone="zh_cn.utf-8" lc_measurement="zh_cn.utf-8" lc_identification="zh_cn.utf-8"
|