字符编码在您的场景中的多个位置发挥规则
- 客户端使用哪种编码将参数发送到服务器
- mysql 服务器使用哪种编码来解释从 php 脚本发送到服务器的字符
- mysql 服务器使用哪种编码将结果发送回 php 脚本
- mysql服务器使用哪种编码来存储数据
- 客户端/浏览器使用哪种编码来呈现从 php 脚本发送到客户端/浏览器的数据
将整个链保持为 utf-8 编码是最简单的:
将发送到浏览器的 html 文档的字符编码设置为 utf-8,例如通过default_charset。
向 mysql 服务器指示连接字符集是 utf-8,例如通过在PDO-MYSQL DSN中设置 charset 属性。
使用 utf-8 作为默认字符集创建表,而不为字段本身指定另一种编码。
自包含示例:
<?php
ini_set('default_charset', 'utf-8');
$fn = isset($_POST['val']) ? 'doDatabase' : 'doForm';
doHtml($fn);
function doHtml($fn) { ?>
<html>
<head><title>...</title></head>
<body>
<?php $fn(); ?>
</body>
</html>
<?php
}
function doForm() { ?>
<form method="POST" action="?">
<div>
<input type="text" name="val" value="®" />
<input type="submit" />
</div>
</form>
<?php
}
function doDatabase() {
$pdo = new PDO('mysql:host=localhost;dbname=test;charset=utf8', 'localonly', 'localonly');
$pdo->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
$pdo->setAttribute(PDO::ATTR_EMULATE_PREPARES, false);
$pdo->exec('
CREATE TEMPORARY TABLE soFoo (
id int auto_increment,
val varchar(30),
primary key(id)
) DEFAULT CHARACTER SET utf8
');
$stmt = $pdo->prepare('INSERT INTO soFoo (val) VALUES (?)');
$stmt->execute( array($_POST['val']) );
$stmt = null;
foreach( $pdo->query('SELECT * FROM soFoo', PDO::FETCH_ASSOC) as $row ) {
echo 'row: ', join(', ', $row), "<br />\r\n";
}
}