电话
400 9058 355
PHP 默认字符集需在php.ini中设default_charset="UTF-8"并重启服务器;MySQL连接须用utf8mb4(mysqli→set_charset,PDO→DSN加charset=utf8mb4);HTML需meta charset与HTTP头一致;文件保存为UTF-8无BOM。
PHP 本身没有“安装时自动设为 UTF-8”的开关,default_charset 的默认值在不同版本中也不同(PHP 5.6 是 UTF-8,PHP 7.0+ 默认仍是 UTF-8,但很多旧环境或自编译安装可能被覆盖)。关键不是“怎么设”,而是“在哪设、设哪里才真正生效”。
这是最直接控制 PHP 输出 HTTP 响应头中 Content-Type 字符集的方式。但它只影响 header("Content-Type: text/html") 类响应,不改变 MySQL 连接、文件读写或内部字符串处理逻辑。
default_charset 必须写在主 php.ini 文件中(可通过 php --ini 或 phpinfo() 查看加载路径)default_charset = "UTF-8",取消注释并确保值是
"UTF-8"(带英文双引号,大小写不敏感但建议大写 U 和小写 tf-8)[PHP] 段落下方systemctl restart apache2 或 service php-fpm restart),仅 reload 不生效即使 default_charset 是 UTF-8,PHP 连接 MySQL 时默认用的是 latin1(尤其老版本 mysqli/pdo),导致 SELECT 出来的中文变乱码。这不是 PHP 字符集问题,而是连接协议层没协商好。
mysqli 时,连接后立即执行:$mysqli->set_charset('utf8mb4');(注意是 utf8mb4,不是 utf8)PDO 时,在 DSN 中加入 ;charset=utf8mb4:$pdo = new PDO('mysql:host=localhost;dbname=test;charset=utf8mb4', $user, $pass);init_commands 或 SET NAMES,兼容性差且易被忽略浏览器按 HTML 中的 或 HTTP Content-Type 头解析页面。两者不一致时,以 HTTP 头为准;若 HTTP 头没带 charset,才 fallback 到 。
header('Content-Type: text/html; charset=UTF-8'); 中写:最容易被忽略的是:MySQL 的 utf8 实际只支持 BMP 字符(不支持 emoji),必须用 utf8mb4
+ 对应的表/列字符集 + 连接层设置三者统一。光改 php.ini 只解决一半问题。
邮箱:8955556@qq.com
Q Q:8955556
本文详解如何将Go官方present工具(用于生成HTML5...
PySNMP在不同版本中对SNMP错误状态(errorSta...
time.Sleep仅阻塞当前goroutine,其他gor...
PHPfopen()创建含特殊符号的文件名失败主因是操作系统...
WooCommerce中通过代码为分组产品动态聚合子商品的属...
io.ReadFull返回io.ErrUnexpectedE...
本文详解Yii2中控制器向视图传递ActiveRecord数...
本文详解为何通过wp_set_object_terms()为...
Pytest中使用@mock.patch类装饰器会导致补丁泄...
带缓冲的channel是并发安全的FIFO队列;make(c...