答案:PHP乱码需统一UTF-8编码。1. PHP文件保存为UTF-8无BOM;2. 添加header("Content-Type: text/html; charset=utf-8");3. 数据库用utf8mb4,连接时设置charset;4. 页面加,表单提交保持编码一致;5. 使用mbstring扩展处理多字节字符,避免截断。全程统一则可避免乱码。

PHP中出现文字乱码,尤其是中文或多语言字符显示异常,通常与编码不一致有关。问题可能出在文件编码、数据库存储、HTTP响应头或浏览器解析等多个环节。要彻底解决乱码,需确保整个数据流转过程使用统一的字符编码(推荐UTF-8)。
1. 确保PHP文件本身为UTF-8编码
编辑PHP源文件时,务必保存为UTF-8无BOM格式。如果使用记事本等工具保存,容易带入BOM头,导致输出前出现空白或乱码。
建议:- 使用专业编辑器如VS Code、Sublime Text、PhpStorm,并设置默认编码为UTF-8。
- 检查并转换已有文件编码:可用编辑器批量转码,或使用命令行iconv工具。
2. 设置正确的HTTP响应头
浏览器需要知道服务器返回的内容编码类型,否则会按默认编码(如GBK)解析,造成乱码。
解决方法:- 在PHP脚本最开始添加:header("Content-Type: text/html; charset=utf-8");
- 该语句应放在任何输出之前(包括空格和echo)。
3. 数据库连接与存储编码统一为UTF-8
即使页面是UTF-8,若数据库或连接使用其他编码(如latin1),读取中文仍会乱码。
立即学习“PHP免费学习笔记(深入)”;
关键步骤:- 数据库和表结构使用utf8mb4字符集(支持emoji等四字节字符)。
- 连接数据库后设置字符集:
mysqli_set_charset($connection, 'utf8mb4');
或执行SQL:SET NAMES utf8mb4; - PDO连接时在DSN中指定:
$pdo = new PDO("mysql:host=localhost;dbname=test;charset=utf8mb4", $user, $pass);
4. 表单提交与接收编码处理
用户通过表单提交数据时,浏览器按页面编码发送,PHP接收后需保持一致。
注意事项:- HTML页面声明编码:
- 确保form提交方式(GET/POST)下,PHP未对字符串做错误转码。
- 避免使用iconv或mb_convert_encoding进行不必要的转换,除非明确目标编码。
5. 使用多语言时推荐mbstring扩展
PHP默认字符串函数(strlen、substr等)不支持多字节字符,可能导致截断乱码。
建议:- 启用mbstring扩展。
- 使用mb_strlen()、mb_substr()等函数处理中文。
- 在php.ini中设置:mbstring.internal_encoding = UTF-8











