开启 CURLOPT_FOLLOWLOCATION 并设置 CURLOPT_MAXREDIRS 可实现安全的自动跳转,通过 curl_getinfo 可获取最终 URL、跳转次数和状态码,适用于登录跳转、短链解析等场景。

在使用 PHP 的 cURL 扩展发起 HTTP 请求时,服务器返回重定向响应(如 301、302)是常见情况。如果不做特殊处理,cURL 默认不会自动跳转到新的 URL,需要手动配置相关选项来启用自动跳转并控制跳转行为。
开启自动跟随重定向(followlocation)
要让 cURL 自动跟随 Location 头部进行跳转,需设置 CURLOPT_FOLLOWLOCATION 为 true。
- 设为 true 后,cURL 会自动请求服务器返回的新的跳转地址
- 适用于处理登录跳转、短链跳转、页面迁移等场景
示例代码:
$ch = curl_init(); curl_setopt($ch, CURLOPT_URL, "http://example.com/redirect"); curl_setopt($ch, CURLOPT_RETURNTRANSFER, true); curl_setopt($ch, CURLOPT_FOLLOWLOCATION, true); // 开启跳转 $response = curl_exec($ch); curl_close($ch);
限制最大跳转次数(max_redirects)
无限制跳转可能导致无限循环或性能问题,可通过 CURLOPT_MAXREDIRS 设置最大跳转次数。
立即学习“PHP免费学习笔记(深入)”;
- 建议设置一个合理值,如 5 或 10
- 防止因配置错误导致的死循环
示例代码:
curl_setopt($ch, CURLOPT_MAXREDIRS, 10); // 最多跳转10次
获取最终有效 URL 和跳转信息
有时需要知道请求最终落在哪个地址,可以使用 curl_getinfo() 获取详情。
常用信息包括:
- url:最终有效请求地址
- redirect_count:实际跳转次数
- http_code:最后返回的状态码
示例:
$info = curl_getinfo($ch); echo "Final URL: " . $info['url'] . "\n"; echo "Redirect Count: " . $info['redirect_count'] . "\n"; echo "HTTP Code: " . $info['http_code'];
基本上就这些。开启 followlocation 并设置 maxredirs 是处理重定向的基本做法,既能保证正常跳转,又能避免潜在风险。











