好得很程序员自学网

<tfoot draggable='sEl'></tfoot>

php获取get参数乱码怎么办

在这里请注意 var_dump 出变量的长度只有 4 ,很显然,两个中文字的长度在 utf-8 编码下肯定不止 4 个字节

然后我们再看一下 Firefox 的访问这个页面 url

FireFox 会自动将中文 url 编码,所以我们可以看到测试变成了 %B2%E2%CA%D4 ,很明显,这里一个字是两个字节,是 gb2313 、 gbk 等中文编码格式,而不是 utf-8 编码。(推荐:《PHP视频教程》)

如果我们把页面的编码切换为 gbk ,中文参数就会显示正常,参见下图

这时一个有趣的问题就诞生了:像 emlog 的中文标签这样的参数怎么就没有乱码呢?

多方测试后,我发现了一个小小的区别:

emlog 中文参数的链接是在页面上生成的,而上面我们测试则用手直接在地址栏输入的,

如果我们直接输入例如 http://be-evil.org/?tag= 原创 这样的链接,程序同样会提示找不到标签

测试代码如下:


测试结果,正常显示:


请注意上图中红框标出的 url 编码,这次测试两个字是由 6 个字节组成,而不是先前的 2 个字节,因此表明中文参数已经正确的成为 utf-8 编码。

那么,是什么导致这个问题的发生呢?

答案是浏览器默认编码 在作怪,我们都用的是中文系统,浏览器默认的编码自然也会设置为本地化,例如我自己电脑上的 IE 的 FireFox 的默认编码都是 gb 系列的,请参看下图:

IE 的默认设置:


Firefox 的默认设置:


正因为这个设置,让浏览器在请求用户输入的 url 时会默认把 url 中的中文以默认的编码格式发送而不是以页面的编码格式发送,这就是为什么页面中带有中文的链接正常而我们手动输入的链接会乱码的原因。同理,如果我们把浏览器的默认编码调整为 utf-8 ,那么输入 url 中的中文则会按照 utf-8 编码。

除了上面的之外,还有以下情况会出现这种情况:

如果 gbk 编码的页面生成的地址链接到 utf-8 的页面, gbk 页面的中文是按照 gbk 的格式编码传送给下个页面,那么 utf-8 编码接收后肯定会出现乱码。

IIS 的 url 重写模块,重写后的中文编码也是 gbk ,如果你的页面是 utf-8 编码,那么重写参数将会失效。

像这些情况,我们就需要使用 php 内置的转码函数来处理编码问题了:

方案 1 :

$str =iconv("gb2312","utf-8",$str);

方案 2:

mb_convert_encoding($str,"utf-8", "gb2312");

希望本文对那些因为编码问题而抓破头的 PHPer 们有所帮助 :)

以上就是php获取get参数乱码怎么办的详细内容!

查看更多关于php获取get参数乱码怎么办的详细内容...

  阅读:38次