PHP 获取短链接目标 URL 返回 404,主因是目标服务器校验 User-Agent、Referer 或拒绝 HEAD 请求;需启用 cURL 自动跳转、设置伪造浏览器头、必要时禁用 SSL 验证,并用“Copy as cURL”比对请求头。

用 PHP 获取短链接跳转目标 URL 时返回 404
PHP 用 file_get_contents() 或 cURL 请求短链接却收到 404,大概率不是短链服务宕机,而是目标服务器在拦截非浏览器请求。短链接本身有效,但它的最终跳转目标(即长 URL)可能做了 Referer、User-Agent 或请求头校验。
curl 默认不跟随重定向,且无 User-Agent 导致被拒
很多目标站会拒绝没有 User-Agent 的请求,或只允许特定客户端访问。PHP 的 file_get_contents() 默认不处理 3xx 重定向,而 cURL 默认也不自动跳转,需显式开启。
-
curl_setopt($ch, CURLOPT_FOLLOWLOCATION, true)必须启用,否则停在 302 而不继续请求目标页 -
curl_setopt($ch, CURLOPT_USERAGENT, 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36')几乎必加 - 部分站点还检查
Referer,可临时设为来源域名:curl_setopt($ch, CURLOPT_REFERER, 'https://example.com') - 禁用 SSL 验证(仅调试):
curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, false),避免证书错误中断
目标服务器返回 404 的真实原因判断方法
别急着改 PHP 代码,先人工验证链路是否通畅:
- 用浏览器打开短链接,确认能否正常跳转并显示内容(排除短链失效)
- F12 打开开发者工具 → Network → 刷新页面 → 找到最终跳转后的那个
GET请求 → 看状态码和响应头 - 右键该请求 → “Copy as cURL”,粘贴到终端执行,看是否也 404 —— 若终端也 404,说明问题出在请求头或环境,而非 PHP 特有
- 对比浏览器请求头和 PHP cURL 请求头(尤其
User-Agent、Accept、Sec-Fetch-*等),补全缺失项
一个最小可用的 PHP 还原函数示例
以下函数能稳定获取大多数短链接的最终目标 URL(非内容),适用于微博、微信、t.cn、bit.ly 等常见服务:
立即学习“PHP免费学习笔记(深入)”;
function resolveShortUrl($url) {
$ch = curl_init();
curl_setopt($ch, CURLOPT_URL, $url);
curl_setopt($ch, CURLOPT_NOBODY, true); // HEAD 请求,更快
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
curl_setopt($ch, CURLOPT_FOLLOWLOCATION, true);
curl_setopt($ch, CURLOPT_USERAGENT, 'Mozilla/5.0 (X11; Linux x86_64) AppleWebKit/537.36');
curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, false);
curl_exec($ch);
$target = curl_getinfo($ch, CURLINFO_EFFECTIVE_URL);
curl_close($ch);
return $target;
}
注意:CURLINFO_EFFECTIVE_URL 返回的是最后一次跳转后的 URL,不是响应体内容。如果目标站对 HEAD 请求返回 405,可改用 CURLOPT_NOBODY => false + CURLOPT_HEADER => true 后手动解析 Location 头,但更重也更兼容。
真正麻烦的不是跳转逻辑,而是有些目标站会动态生成 URL、校验时间戳、加密参数,甚至要求 JS 渲染后才暴露真实地址——这种短链 PHP 无法还原,得上 Puppeteer 或 Playwright。











