短链接还原php返回404_排查目标服务器是否正常【解答】

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-AgentAcceptSec-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。