PHP接收GET中文参数乱码的根本原因是浏览器、URL传输、PHP文件编码及服务器配置四者不一致;需统一为UTF-8无BOM编码,前端用encodeURIComponent()编码,PHP无需额外解码,HTML和服务器配置也须同步设为UTF-8。

PHP接收GET中文参数显示问号或乱码
根本原因是浏览器编码、URL传输编码、PHP脚本编码、服务器配置四者不一致,最常见的是浏览器用UTF-8编码发送,但PHP文件本身保存为GBK,或$_GET未做正确解码。
确认当前PHP文件的源码编码格式
用编辑器(如VS Code、Notepad++)打开PHP文件,检查右下角显示的编码。必须是UTF-8无BOM —— 如果显示GBK/GB2312/ANSI,直接另存为UTF-8无BOM,否则$_GET['name']即使接收到正确字节,也会被PHP按错误编码解析成乱码。
- Windows记事本默认保存为ANSI(即GBK),务必避免
- VS Code中点击右下角编码 → “Save with Encoding” → 选
UTF-8 - 用
file -i your.php(Linux/macOS)可验证:输出含charset=utf-8才对
URL中的中文必须经过encodeURIComponent()编码
前端JavaScript发请求时,不能直接拼接中文到URL里。比如?q=你好会因浏览器差异导致编码不可控;必须用JS原生编码函数处理:
const keyword = '你好';
const url = `search.php?q=${encodeURIComponent(keyword)}`;
这样生成的URL是search.php?q=%E4%BD%A0%E5%A5%BD,PHP才能稳定识别为UTF-8字节流。若用encodeURI(),它不编码/ ? : @ & = + $ , #等,容易破坏URL结构。
立即学习“PHP免费学习笔记(深入)”;
$_GET值无需额外urldecode()或iconv()
PHP内置已自动对$_GET执行urldecode(),且按当前脚本编码(即你保存的UTF-8)解释字节。只要前面三步(文件编码、URL编码、HTTP头)统一为UTF-8,$_GET['q']就是正确的UTF-8字符串,可直接使用或存入数据库。
- 不要写
iconv('gbk', 'utf-8', $_GET['q'])—— 这反而会二次转码出错 - 不要用
mb_convert_encoding($_GET['q'], 'UTF-8', 'auto')—— 没必要,且auto可能误判 - 如果页面HTML声明了
锛屾祻瑙堝櫒浼氱敤GBK瑙f瀽鍝嶅簲锛屽










