php放入数据库的信息乱码如何解决

本篇内容主要讲解“php放入数据库的信息乱码如何解决”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“php放入数据库的信息乱码如何解决”吧!

创新互联公司专注为客户提供全方位的互联网综合服务,包含不限于做网站、网站制作、岳阳楼网络推广、成都微信小程序、岳阳楼网络营销、岳阳楼企业策划、岳阳楼品牌公关、搜索引擎seo、人物专访、企业宣传片、企业代运营等,从售前售中售后,我们都将竭诚为您服务,您的肯定,是我们最大的嘉奖;创新互联公司为所有大学生创业者提供岳阳楼建站搭建服务,24小时服务热线:028-86922220,官方网址:www.cdcxhl.com

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

一、问题呈现

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

18.8.html


添加信息

添加员工信息



员工姓名:

员工年龄:

员工工资:



18.8.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,将这两个文件置于站点文件夹下。php放入数据库的信息乱码如何解决

  2. 启动phpstudy

php放入数据库的信息乱码如何解决

  1. 在mysql中创建所需的数据库的数据表,代码如下

create database mytest;use mytest;create table employee(
id integer primary key,
name char(10),
age integer,
salary float);

php放入数据库的信息乱码如何解决

  1. 在浏览器中访问网址

   http://localhost:80/mytest/18.8.html

PS:访问站点时的端口号需要与站点设置的端口号相同,这里设置站点时指定端口为80,
php放入数据库的信息乱码如何解决

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

php放入数据库的信息乱码如何解决

跳转到18.8.php页面,提示数据添加成功
php放入数据库的信息乱码如何解决

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

    代码如下

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

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

输出结果如下:

php放入数据库的信息乱码如何解决

问题出现,即name对应的数据被显示为乱码

二、问题处理

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

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

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

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;

显示删除成功

php放入数据库的信息乱码如何解决

5.重新录入数据

php放入数据库的信息乱码如何解决

php放入数据库的信息乱码如何解决

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

php放入数据库的信息乱码如何解决

中文显示成功!

三、问题分析及补充

上述流程,很好地印证我们的猜测——这个中文乱码问题和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放入数据库的信息乱码如何解决

这时同样出现中文乱码的情况,不同的是,这是由于php页面本身的编码不匹配导致。

到此,相信大家对“php放入数据库的信息乱码如何解决”有了更深的了解,不妨来实际操作一番吧!这里是创新互联网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!


当前名称:php放入数据库的信息乱码如何解决
文章网址:http://myzitong.com/article/iisepi.html