解决php pdo传中文给mysql乱码的方案

本文介绍了解决PHP使用PDO向MySQL传输中文数据时出现乱码的方法,包括设置HTML页面编码、PHP头部编码、数据库字符集及PDO连接命令。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

关于如何解决php 用pdo 传中文数据给mysql乱码的问题,我在网上搜了好久,总结了一下,不足的地方请大家见谅。

linux下文件的存储格式本身就是utf8格式 这个我们可以不用变化。

html页面

我们要在<head>加上这句代码

<meta http-equiv="Content-Type" content="text/html:charset=utf-8">

在php 页面

在<?php 后面加上

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

建立数据库的时候,比如叫做test

create table test

(

     name varchar(200)  not null

)ENGINE=InnoDB DEFAULT CHARSET=utf8;

后面的ENGINE=InnoDB DEFAULT CHARSET=utf8 是为了设置数据库编码格式为utf8格式

建立php与mysql链接的时候

<?php
$dbms='mysql';
$host='localhost';
$dbName='BBS';
$user='root';
$pass='784863455';
$dsn="$dbms:host=$host;dbname=$dbName";
try
{
    $pdo=new pdo($dsn,$user,$pass,array(PDO::MYSQL_ATTR_INIT_COMMAND=>"set names utf8"));
}catch(PDOException $e)
{
    die ("connect error !".$e->getMessage()."</br>");
}

红色那部分保证了传送过去的数据为utf8模式

然后就可以愉快的传输中文啦

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值