php放入数据库的信息乱码的解决办法:1、修改HTML文件编码为“”;2、在PHP文件中添加“header("Content-Type:text/html;charset=utf-8");”;3、通过在控制台窗口中输入“set names gbk;charset gbk;”设置MySQL编码;4、重启浏览器和服务器即可。

本教程操作环境:windows7系统、PHP5.4版、DELL G3电脑
php写入mysql数据库的中文乱码问题
一、问题呈现
以下为两个关键的文件。其中的html向用户获取数据输入,php实现将这些数据写入到数据库。
立即学习“PHP免费学习笔记(深入)”;
18.8.html
添加信息 添加员工信息
18.8.php
query("SET NAMES gbk");
//检测连接
if(!$db){
die("数据库连接失败:".mysqli_connect_error());
}
//$q = "select * from employee";
$q = "INSERT INTO employee(name,age,salary)
VALUES('$name',$age,$salary)";
if(!mysqli_query($db,$q)){
echo "员工信息添加失败";
}else{
echo "员工信息已经成功添加";
};
mysqli_close($db);
?>搭建了本地测试站点
mytest,将这两个文件置于站点文件夹下。
启动phpstudy

- 在mysql中创建所需的数据库的数据表,代码如下
create database mytest;use mytest;create table employee( id integer primary key, name char(10), age integer, salary float);

- 在浏览器中访问网址
http://localhost:80/mytest/18.8.html
PS:访问站点时的端口号需要与站点设置的端口号相同,这里设置站点时指定端口为80,
- 输入数据,点击上传数据

跳转到18.8.php页面,提示数据添加成功
-
在mysql控制台中查看已添加的数据
代码如下
set names gbk; charset gbk; set character_set_server=gbk; set character_set_database=gbk; select * from employee;
PS:前四行代码用于设置mysql的编码格式,使mysql能够正常显示中文。
输出结果如下:

问题出现,即name对应的数据李逍遥被显示为乱码鏉庨?閬
二、问题处理
不难猜测,这个中文乱码问题和html、php、mysql的编码不一致有关。
根据测试,按照如下进行修改即可。
1.对于18.8.html
将
改为
即指定18.8.html的编码为gbk
2.对于18.8.php
保持
header("Content-Type:text/html;charset=utf-8");不变。
即保持18.8.php的编码格式为utf-8
基于Intranet/Internet 的Web下的办公自动化系统,采用了当今最先进的PHP技术,是综合大量用户的需求,经过充分的用户论证的基础上开发出来的,独特的即时信息、短信、电子邮件系统、完善的工作流、数据库安全备份等功能使得信息在企业内部传递效率极大提高,信息传递过程中耗费降到最低。办公人员得以从繁杂的日常办公事务处理中解放出来,参与更多的富于思考性和创造性的工作。系统力求突出体系结构简明
3.对于mysql
在控制台窗口中输入如下代码
set names gbk;charset gbk;set character_set_server=gbk;set character_set_database=gbk;
即设置mysql的编码为gbk
4.删除之前录入的信息
代码如下
use mytest;delete from employee;
显示删除成功

5.重新录入数据


6.在数据库中查看录入的数据
use mytest;select * from employee;

中文显示成功!
三、问题分析及补充
上述流程,很好地印证我们的猜测——这个中文乱码问题和html、php、mysql的编码不一致有关。
解决问题的关键,便是将编码格式进行统一。
我们将html和mysql设置为gbk编码。
那么问题来了!
1.为什么php的编码格式不用与html和mysql进行统一呢?
因为html从用户获取输入,则这些数据遵循与该html页面相同的编码格式,即gbk。
在18.8.php中,仅仅只是将获取的数据写入mysql数据库,没有对接收到的数据进行二次处理(比如编码),所以php的编码格式为utf-8时,对于该中文乱码问题无直接影响,可以不进行修改。
在mysql中,因为从页面中获取并写入的数据遵循gbk编码,所以只需要设置mysql的编码格式为gbk,即可正常显示中文数据了。
2.我把php的编码格式也设置为gbk,怎么php页面也出现乱码了?
即改header为
header("Content-Type:text/html;charset=gbk");php页面显示为
这时同样出现中文乱码的情况,不同的是,这是由于php页面本身的编码不匹配导致。
3.为什么我一波操作下来,还是中文乱码呀?
在我撰写这篇博客的期间,不止一次遇到这样的情况。
所有的操作都准确无误,但是结果依然是乱码,和原来的结果没有任何区别。
如果您也遇到这样的问题,可以尝试:
重启浏览器和服务器(即phpstudy)
清理浏览器缓存
重新输入数据(这是必须的)
更换浏览器做测试










