1.PHP解决中文乱码问题
很多情况下,程序中出现中文输出时,页面会显示乱码
一般地原因有两种
- 编码(charset)设置错误,导致浏览器以错误的编码来解析,从而出现乱码
- 文件被以错误的编码方式打开并保存,比如GBK编码的文件,以UTF-8编码格式打开,再以UTF-8格式保存,就会出现乱码问题
将乱码情况分类并做出具有针对性的解决方案
1.1 解决HTML中页面中文乱码问题
如果你的HTML文本文件出现了筹码问题,那么你可以在head标签里面加入UTF-8编码(国际化编码):UTF-8是没有国家的编码,也就是独立一种语言,任何语言都可以使用的。
<meta http-equiv="content-Type" content="text/html;charset=utf-8" />
1.2 HTML和PHP混合的页面解决方案
如果在HTML和PHP混编,除了按照第一个方法所说的操作之外,还需要在PHP文件的了上面加入这句代码:
<?php header("content-type:text/html;charset=utf-8"); ?>
1.3 纯PHP页面的中文乱码问题(数据是静态的)
如果PHP页面出现筹码,只需要在页面的开始处加入下面代码
<?php header("contnet-type:text/html;charset=utf-8"); ?>
1.4 PHP+MySQL中文乱码问题
这个除了按第三种所说的操作之外,还要在数据查询/修改/增加之前加入数据库编码。
而且需要注意的是,这里的UTF8和之前的不一样, 中间是没有横线的
<?php mysql_query('SET NAMES UTF8'); ?>
如果数据库版本大于4.1,可以在链接数据库操作后,设置一个字符编码,如下
$conn = mysqli_connect('localhost','root','root','db_name'); mysqli_set_charset($conn,'utf8');
UTF-8编码只是其中一种编码,如果不想使用utf-8编码,也可以使用其他编码,这需要使用编码转换
有一点需要注意,在需要做数据库操作的php程序前加的
mysql_query("set names encoding");
编码,一定要和php编码一致,如果php编码是gb2312,那mysql编码就是gb2312,如果php页面编码是utf-8,mysql编码就是utf-8。这样保持数据与页面编码一致性,插入或检索数据时较少会出现筹码情况