• paip.WEB乱码的解决流程


    paip.WEB乱码的解决流程

    作者Attilax , 1466519819@qq.com


    环境是 PHP5.2 +MYSQL 5.0 ..

    发现一段程序出现显示乱码..

    首先,查询数据库。。。用MYSQL GUI TOOL查看纪录内容,是乱码..都是问号 ??  估计字段编码是LATIN的.一看 ,果然是LATIN的。。修改为

    UTF8的。。只改了表编码不行的,重要的是更改字段的编码。。

    测试,通过表单添加一条记录,汉字字段用两个汉字测试,发现还是乱码。不过数据库里面不是问号了,变成四个很罕见的繁体字了,这说明从表单

    的过来的应该是GBK编码,存到DB里变成UTF8,就字数变多了。。。

     接着,挂载调试起,单步调试,发现表单收集果然是四个繁体字,查看 表单 <meta http-equiv="Content-Type" content="text/html;

    charset=gb2312">..至于APACHE,PHP的解码用的编码,估计是UTF8的...

    将编码从UTF8转为GBK,    mb_convert_encoding($name, "UTF-8", "gb2312");再次调试,变量上来是正常的。。

    这样表单提交后就变成正常的文字了..从数据库查询,是正常文字了...

    不过显示在页面的时候还是乱码.四五个不认识的繁体汉字..查看PHP连接DB代码..mysql_select_db($database_mysqlconn,$mysql);
    mysql_query("set names 'utf8'"); //select 数据库之后加多这一句..应该是正常的使用UTF8读出数据

    调试PHP.发现数据从DB里出来已经是正常的了..就是显示的时候乱码..

    页面编码是GBK的..不过PHP输出DB数据的时候应该是UTF8,导致了此问题..使用mb_convert_encoding转码..将数据转为GBK输出..

    终于,一切正常了..不过MS mb_convert_encoding有BUG,从UTF8转GBK有些汉字会乱码,奇怪地.

  • 相关阅读:
    感谢一个名叫“祯玥”的姑娘
    下一代互联网
    伤心时要读的三十八句
    任何企业的竞争,归根结底都是智能的竞争
    互联网创业必须过的槛(转)
    钻到牛角尖里面去,想开公司必需知道的奥秘
    重游草堂
    牛根生:我们应该学会“三换思维”
    领导者的感染力和传染力
    幸福是一种心境(转)
  • 原文地址:https://www.cnblogs.com/attilax/p/15199761.html
Copyright © 2020-2023  润新知