[问题分析处理]php写入mysql数据库中文乱码

4 篇文章 0 订阅
2 篇文章 0 订阅

php写入mysql数据库的中文乱码问题

一、问题呈现

以下为两个关键的文件。其中的html向用户获取数据输入,php实现将这些数据写入到数据库。

18.8.html

<!doctype html>
<html>
<head>
	<meta charset="utf-8" />
<title>添加信息</title>
</head>
<body>
	<h2>添加员工信息</h2>
	<form action="18.8.php" method="post" >
		员工姓名:
		<input name="name" type="text" size="20" /> <br />
		员工年龄:
		<input name="age" type="text" size="3" /> <br/>
		员工工资:
		<input name="salary" type="text" size="6" /> <br />
		<input name="submit" type="submit" value="上传数据" />
	</form>
</body>
</html>
 

18.8.php

<?php
header("Content-Type:text/html;charset=utf-8");
$name = $_POST['name'];
$age = $_POST['age'];
$salary = $_POST['salary'];

$servername = "localhost";
$username = "root";
$password = "root";
$dbname = "mytest";

// 创建连接
$db = new mysqli($servername,$username,$password,$dbname);
$db->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);
?>
  1. 搭建了本地测试站点mytest,将这两个文件置于站点文件夹下。在这里插入图片描述

  2. 启动phpstudy

在这里插入图片描述

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

在这里插入图片描述

  1. 在浏览器中访问网址
   http://localhost:80/mytest/18.8.html

PS:访问站点时的端口号需要与站点设置的端口号相同,这里设置站点时指定端口为80,
在这里插入图片描述

  1. 输入数据,点击上传数据

在这里插入图片描述

​ 跳转到18.8.php页面,提示数据添加成功
在这里插入图片描述

  1. 在mysql控制台中查看已添加的数据

    代码如下

   set names gbk;
   charset gbk;
   set character_set_server=gbk;
   set character_set_database=gbk;
   select * from employee;

PS:前四行代码用于设置mysql的编码格式,使mysql能够正常显示中文。

输出结果如下:

在这里插入图片描述

问题出现,即name对应的数据李逍遥被显示为乱码鏉庨?閬


二、问题处理

不难猜测,这个中文乱码问题和htmlphpmysql的编码不一致有关。

根据测试,按照如下进行修改即可。

1.对于18.8.html

	<meta charset="utf-8" />

改为

	<meta charset="gbk" />

即指定18.8.html的编码为gbk

2.对于18.8.php

保持

header("Content-Type:text/html;charset=utf-8");

不变。

即保持18.8.php的编码格式为utf-8

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;

在这里插入图片描述

中文显示成功!

三、问题分析及补充

上述流程,很好地印证我们的猜测——这个中文乱码问题和htmlphpmysql的编码不一致有关。

解决问题的关键,便是将编码格式进行统一。

我们将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.为什么我一波操作下来,还是中文乱码呀?

在我撰写这篇博客的期间,不止一次遇到这样的情况。

所有的操作都准确无误,但是结果依然是乱码,和原来的结果没有任何区别。

如果您也遇到这样的问题,可以尝试:

  1. 重启浏览器和服务器(即phpstudy)
  2. 清理浏览器缓存
  3. 重新输入数据(这是必须的)
  4. 更换浏览器做测试

本篇文章为本人原创。

转发请注明出处。

欢迎评论留言与我交流。

如果文章内容有疏漏,欢迎您在评论区指出。

  • 4
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 4
    评论
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

wingaso

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值