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 打开中文乱码,可在写入前加
xEFxBBxBF(UTF-8 BOM) - 写完记得
fclose(),否则文件可能不完整
$fp = fopen('./outputs/links_' . date('Ymd_His') . '.csv', 'w'); fputs($fp, "xEFxBBxBF"); // 写入 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, "xEFxBBxBF"); 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,但那就是另一回事了。