PHP获取URL查询参数有五种方法:一、用$_GET自动解析;二、parse_url()与parse_str()组合解析任意URL;三、$_SERVER['QUERY_STRING']手动解析;四、filter_input()安全过滤;五、注意URL编码处理。

如果您的PHP脚本需要从当前请求的URL中提取查询参数(即问号?后面的部分),则需依赖服务器变量或内置函数解析这些键值对。以下是获取URL中查询参数的具体方法:
一、使用 $_GET 超全局数组
$_GET 是PHP内置的超全局数组,自动将URL查询字符串中所有参数解析为键值对,适用于标准GET请求。
1、确保URL格式为 https://example.com/page.php?name=John&age=30。
2、在PHP文件中直接访问 $_GET['name'] 获取值 John。
立即学习“PHP免费学习笔记(深入)”;
3、使用 isset($_GET['age']) 判断参数是否存在,避免未定义索引警告。
二、使用 parse_url() 与 parse_str() 组合解析
当需要从任意URL字符串(非当前请求)中提取查询参数时,parse_url() 可分离URL各部分,parse_str() 可将查询字符串转换为关联数组。
1、调用 parse_url('https://example.com/test.php?id=123&tag=php', PHP_URL_QUERY) 提取查询字符串 id=123&tag=php。
2、将提取结果传入 parse_str($query, $output),生成数组 $output['id'] = '123'。
3、检查 $output 是否为数组且非空,再进行后续处理。
三、使用 $_SERVER['QUERY_STRING'] 手动解析
$_SERVER['QUERY_STRING'] 直接返回原始查询字符串,适合需保留原始编码或自定义解析逻辑的场景。
1、读取 $_SERVER['QUERY_STRING'] 得到未解码的字符串,如 q=hello%20world&lang=zh。
2、对整个字符串调用 urldecode() 进行解码,再按 & 和 = 分割处理。
3、遍历分割后的每组键值,使用 trim() 清除空格,并存入自定义数组。
四、使用 filter_input() 安全获取指定参数
filter_input() 提供类型验证和过滤能力,可防止注入或非法数据进入业务逻辑。
1、调用 filter_input(INPUT_GET, 'email', FILTER_VALIDATE_EMAIL) 验证邮箱格式。
2、若参数不存在或验证失败,函数返回 false,而非触发警告。
3、配合 FILTER_SANITIZE_STRING(PHP 8.1 已弃用,改用 FILTER_SANITIZE_SPECIAL_CHARS)清理输出内容。
五、处理 URL 编码参数的注意事项
浏览器会自动对特殊字符进行URL编码,PHP默认不自动解码$_GET中的值,但实际运行中已由SAPI层完成解码,仅在极少数配置下需手动处理。
1、确认当前环境是否启用 arg_separator.input 设置为 &,否则可能解析失败。
2、对来自非标准来源(如curl构造的URL)的参数,先用 rawurldecode() 处理,再解析。
3、中文等UTF-8字符必须确保页面响应头为 Content-Type: text/html; charset=utf-8,否则显示乱码。










