码迷,mamicode.com
首页 > Web开发 > 详细

你的php网页乱码了吗

时间:2014-12-20 02:15:08      阅读:227      评论:0      收藏:0      [点我收藏+]

标签:php   utf8   mysql   乱码   

一、

学习php的童鞋在编写网页的时候,要是设计到中文内容的储存的时候,大多会出现一个问题就是乱码。一般乱码的话,我们可以检查三个方面

    (1)网页编码是否正确,比如是否在头部那里加入原标签

 

<meta charset="UTF-8">

    (2)检查mysql数据库储存时默认使用的字符集

    (3)检查网页文件的编码,是否为对应的中文编码


------------------

环境:win7+wamp2.2

------------------

二、

下面我们就第二点开始,mysq数据库使用的编码字符集

(1)打开mysql终端,查看当前的设置,确定要修改的范围

show variables like ‘char%‘;

(2)根据结果进行分析,

1、如果你显示的结果和我的差不多,即(只有character_set_system编码为utf8)那么清跟随下面的脚步一步步来


技术分享


2、打开my.ini文件,搜索关键词‘mysqld‘,找到之后,观察是否有这一行

character_set_server = utf8

倘若没有的话,则应该像我这样在其下面添加一句

技术分享

3、再次搜索关键词‘client‘,观察是否有这一行

default_character_set = utf8

没有的话在[client]下面添加上

技术分享

4、保存,重启mysql服务,关闭mysql终端(不然看到的客户端编码不会更新)

5、再次打开终端,我们再次输入

show variables like ‘char%‘;

倘若出现下面的结果,即mysql数据设置成功

技术分享

三、

网页文件编码这个问题最容易被忽略,这个是在保存的时候,选择保存文件编码的格式时设置的。

解决办法:

1、使用notepad++打开该网页文件,然后在“格式”--“转为UTF-8无BOM编码格式”

技术分享

2、保存一下就好了


问题分析:

1、我在编写php的时候已经使用过

<?php mysql_query(‘set names utf8‘); ?>

但是还是出现乱码问题!


分析:使用上面语句,修改的只是三项,这三项分别为

character_set_client

character_set_connection

character_set_results

而且这种修改只是临时性的,关闭终端后又和原来一样

图片说明:

技术分享


2、我们对于第三个乱码问题进行分析一下

(1)使用sublime text3编辑打开php文件。可以看到左下角有编码的信息,可以看到,目前的编码为gb2312

技术分享

(2)当网页加载的时候,那时也就相当于打开一个文件,那时读取的格式时按照gb2312的编码来读取网页文件,而在用户浏览器显示时,因为网页声明了字符集为utf-8,所以会将得到文件按utf-8字符集来解释内容,这是就会出现乱码了,而我们那些从数据库读取出来的内容却没有问题

网页编码

技术分享

原来的gbk编码的文件

技术分享

后来utf-8编码的文件

技术分享

(3)注意一点,sublime text3 的转换编码的时候不太给你,虽然显示转换成功,可是呢?显示还是依旧,还是我们的notepad++给力一点,怎么修改前面有!转换成功之后

技术分享


3、为什么我按照你所说的修改了,在mysql终端下显示,还是乱码呢?

分析:

(1)我们先来看看windows下的cmd的使用的字符集是什么?

技术分享

可以看到,cmd的字符集是gbk,也就是说任何在终端显示的内容会以对应gbk这个字符集,但是我们数据库的中文设置的utf8这个字符集,当我们要显示时,自然会以utf8编码的读取数据库数据,那时编码为utf-8,一到终端就乱套了


(2)那该怎么查看呢?

使用phpmyadmin就好了打,当然得设置我们使用的utf-8编码!

本文出自 “且行且欣赏” 博客,请务必保留此出处http://skytina.blog.51cto.com/6834539/1591864

你的php网页乱码了吗

标签:php   utf8   mysql   乱码   

原文地址:http://skytina.blog.51cto.com/6834539/1591864

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!