PHP获取短链真实URL后,用file_put_contents()写入带时间戳的txt文件,或用fputcsv()生成含BOM的CSV;直接下载则需header()设置类型与附件名,再通过php://output输出,关键要正确配置cURL跳转参数。

用 PHP 获取短链接真实 URL 后,怎么直接保存为 .txt 文件
PHP 本身不自动“下载”或“导出”,所谓“保存为 txt”,本质是:获取到真实 URL 后,用 file_put_contents() 写入本地文件,或用 header() 强制浏览器下载。最稳妥的做法是先写入服务器磁盘,再提供下载链接。
- 确保目标目录有写权限(如
./outputs/),否则file_put_contents()会静默失败 - 写入前建议对 URL 做基础过滤,比如用
filter_var($url, FILTER_SANITIZE_URL)清理非法字符 - 追加写入(
FILE_APPEND)比覆盖更安全,避免单次失败丢失历史记录 - 文件名建议带时间戳,防止重复覆盖:
'urls_' . date('Ymd_His') . '.txt'
file_put_contents(
'./outputs/urls_' . date('Ymd_His') . '.txt',
$real_url . PHP_EOL,
FILE_APPEND | LOCK_EX
);
把多个短链还原结果导出为 .csv(含表头)
CSV 不是简单拼字符串,尤其当 URL 含逗号、换行、双引号时,必须按 RFC 4180 规范转义。PHP 的 fputcsv() 自动处理这些,比手拼 fwrite() 可靠得多。
- 务必用
fopen(..., 'w')打开文件,不是'a'—— CSV 是结构化格式,追加需重读重写整表 - 第一行写表头(如
['short_url', 'real_url', 'timestamp']),之后每行一个数组 - 注意编码:CSV 默认无 BOM,若用 Excel 打开中文乱码,可在写入前加
\xEF\xBB\xBF(UTF-8 BOM) - 写完记得
fclose(),否则文件可能不完整
$fp = fopen('./outputs/links_' . date('Ymd_His') . '.csv', 'w');
fputs($fp, "\xEF\xBB\xBF"); // 写入 UTF-8 BOM
fputcsv($fp, ['short_url', 'real_url', 'timestamp']);
foreach ($results as $row) {
fputcsv($fp, [
$row['short'],
$row['real'],
date('Y-m-d H:i:s', $row['time'])
]);
}
fclose($fp);
还原后直接触发浏览器下载,不存服务器
如果不想在服务器留文件,而是让用户点击就下载 CSV 或 TXT,关键在三步:header() 设置类型 + 编码 + 下载名,然后 echo 内容,最后 exit 阻止后续输出。
-
Content-Type必须匹配内容:CSV 用text/csv,TXT 用text/plain -
Content-Disposition中的filename=值不能含路径、空格或中文(建议用英文+时间戳) - 输出前确保无任何
echo、print、空白符,否则 header 会报headers already sent - 大文件慎用此法——全部加载进内存再输出,容易超
memory_limit
header('Content-Type: text/csv; charset=utf-8');
header('Content-Disposition: attachment; filename="short_links_export.csv"');
header('Pragma: no-cache');
header('Expires: 0');
$output = fopen('php://output', 'w');
fputs($output, "\xEF\xBB\xBF");
fputcsv($output, ['short_url', 'real_url']);
foreach ($results as $r) {
fputcsv($output, [$r['short'], $r['real']]);
}
fclose($output);
exit;
常见错误:cURL 跟跳后没拿到最终 URL,导致导出内容为空
短链还原核心在 HTTP 重定向跟踪,但很多人只调 curl_exec() 却忽略 CURLOPT_FOLLOWLOCATION 和 CURLOPT_NOBODY 的组合逻辑。不设对参数,curl_getinfo($ch, CURLINFO_EFFECTIVE_URL) 返回的仍是原始短链地址。
立即学习“PHP免费学习笔记(深入)”;
- 必须开启
CURLOPT_FOLLOWLOCATION => true,否则 cURL 不自动跳转 - 设
CURLOPT_NOBODY => true可跳过响应体下载,提速且省内存(我们只要头里的 Location 或最终 URL) - 某些短链服务(如微博、微信)会返回 302 但禁用跨域跳转,或加了反爬 headers,此时需补
CURLOPT_USERAGENT和CURLOPT_REFERER - 别依赖
curl_getinfo($ch, CURLINFO_REDIRECT_URL)—— 它只返回最后一次跳转的中间地址,不是最终地址
$ch = curl_init($short_url);
curl_setopt_array($ch, [
CURLOPT_NOBODY => true,
CURLOPT_FOLLOWLOCATION => true,
CURLOPT_RETURNTRANSFER => true,
CURLOPT_USERAGENT => 'Mozilla/5.0 (X11; Linux x86_64)',
CURLOPT_TIMEOUT => 10,
]);
curl_exec($ch);
$real_url = curl_getinfo($ch, CURLINFO_EFFECTIVE_URL);
curl_close($ch);
导出功能看似简单,真正卡住人的往往是权限、编码、header 时机、cURL 跳转配置这几个点。尤其是多层跳转或带 JS 重定向的短链,纯 PHP+cURL 拿不到真实地址,这时候就得换 Puppeteer 或 Playwright,但那就是另一回事了。











