千家信息网

怎样解决php写入数据库中文乱码问题

发表于:2025-01-20 作者:千家信息网编辑
千家信息网最后更新 2025年01月20日,这篇文章将为大家详细讲解有关怎样解决php写入数据库中文乱码问题,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。php写入数据库中文乱码的解决办法:1、
千家信息网最后更新 2025年01月20日怎样解决php写入数据库中文乱码问题

这篇文章将为大家详细讲解有关怎样解决php写入数据库中文乱码问题,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。

php写入数据库中文乱码的解决办法:1、创建数据库并设置"utf8_general_ci"编码;2、用PHP读写数据库,并设置"mysql_query("set names 'utf8'");"即可。

本文操作环境:Windows7系统、PHP7.1版,DELL G3电脑

如何解决php写入数据库中文乱码问题?

PHP写入数据库中文乱码问题

PHP页面转UTF-8编码问题

1.在代码开始出加入一行:

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

2.PHP文件编码问题
点击编辑器的菜单:"文件"->"另存为",可以看到当前文件的编码,确保文件编码为:UTF-8,
如果是ANSI,需要将编码改成:UTF-8。
3.PHP文件头BOM问题:
PHP文件一定不可以有BOM标签
否则,会出现session不能使用的情况,并有类似的提示:
Warning: session_start() [function.session-start]: Cannot send session cache limiter - headers already sent
这是因为,在执行session_start() 的时候,整个页面不能有输出,但是当由于前PHP页面存在BOM标签,
PHP把这个BOM标签当成是输出了,所以就出错了!
所以PHP页面一定要删除BOM标签
删除这个BOM标签的方法:
1.可以用Dreamweaver打开文件,并重新保存,即可以去除BOM标签!
2.可以用EditPlus打开文件,并在菜单"首选项"->"文件"->"UTF-8标识",设置为:"总是删除签名",
然后保存文件,即可以去除BOM标签!
4.PHP以附件形式保存文件的时候,UTF-8编码问题:
PHP以附件形式保存文件,文件名必须是GB2312编码,
否则,如果文件名中有中文的话,将是显示乱码:
如果你的PHP本身是UTF-8编码格式的文件,
需要将文件名变量由UTF-8转成GB2312:

iconv("UTF-8", "GB2312", "$filename");

利用程序来实例字符截取方法

function utf8_substr($str,$len) {   for($i=0;$i<$len;$i++)   {     $temp_str=substr($str,0,1);     if(ord($temp_str) > 127){       $i++;     if($i<$len){       $new_str[]=substr($str,0,3);       $str=substr($str,3);       }     }else {     $new_str[]=substr($str,0,1);     $str=substr($str,1);     }   }   return join($new_str); }

MYSQL数据库使用UTF-8编码的问题

1.用phpmyadmin创建数据库和数据表
创建数据库的时候,请将"整理"设置为:"utf8_general_ci" 或执行语句:

CREATE DATABASE `dbname` DEFAULT CHARACTER SET utf8 COLLATE utf8_general_ci;

创建数据表的时候:如果是该字段是存放中文的话,则需要将"整理"设置为:"utf8_general_ci",
如果该字段是存放英文或数字的话,默认就可以了。
相应的SQL语句,例如:

CREATE TABLE `test` ( `id` INT NOT NULL , `name` VARCHAR( 10 ) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL , PRIMARY KEY ( `id` ) ) ENGINE = MYISAM ;

2.用PHP读写数据库

在连接数据库之后:

$connection = mysql_connect($host_name, $host_user, $host_pass);

加入两行:

mysql_query("set character set 'utf8'");//读库 mysql_query("set names 'utf8'");//写库 //其实读写都可以只加入mysql_query("set names 'utf8'");

就可以正常的读写MYSQL数据库了。

用的appserv-win32-2.5.10做的环境,装这个包的时候用默认的utf8编码。
在写数据库连接文件时,写成:

$conn = mysql_connect("$host","$user","$password"); mysql_query("SET NAMES 'UTF8'"); mysql_select_db("$database",$conn);

然后在做页面时,注意这句:


这样不管输入数据库的中文,还是页面显示,就都正常了。
在DW CS4版里,默认生成的也是utf8页面。
同样的,如果一开始写数据库连接文件时写成: mysql_query("SET NAMES 'GBK'");

那页面也要相应变成:

关于怎样解决php写入数据库中文乱码问题就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。

数据 文件 数据库 编码 问题 UTF-8 页面 中文 标签 乱码 时候 文件名 内容 字段 形式 数据表 文章 方法 更多 环境 数据库的安全要保护哪些东西 数据库安全各自的含义是什么 生产安全数据库录入 数据库的安全性及管理 数据库安全策略包含哪些 海淀数据库安全审计系统 建立农村房屋安全信息数据库 易用的数据库客户端支持安全管理 连接数据库失败ssl安全错误 数据库的锁怎样保障安全 常州人员服务管理软件开发 阴阳师还有春之樱服务器吗 全民水浒的服务器 广安金财网络安全培训 方舟神塔界服务器怎么进 配置ip代理服务器加速软件 上海放心软件开发服务推广 方城客户管理软件开发 敏捷软件开发质量三点价值观 snort 写入数据库 国三网络技术考试题型 无锡软件开发工资怎么样 云服务器跟轻量云服务器区别 创建数据库sql查询语句 安广计算机网络技术专业 霞浦县屯恣网络技术服务部 郑州应用软件开发哪家实惠 软件开发项目验收确认表 工业网络技术面试范文 乐视软件开发工资一般多少 深圳服务器工程师待遇 位于服务器和服务器集群之间 厦门短期兼职网络安全维护 软件开发测试抑郁症的表现 根镜像服务器 编程和服务器管理 计算机网络技术应用哪个专业好 上海工程软件开发发展 什么板块比网络安全 大数据时代网络安全的案例
0