短链接还原php后怎么保存_导出为txt或csv文件方法【介绍】

17次阅读

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

短链接还原php后怎么保存_导出为txt或csv文件方法【介绍】

用 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= 值不能含路径、空格或中文(建议用英文+时间戳)
  • 输出前确保无任何 echoprint、空白符,否则 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_FOLLOWlocationCURLOPT_NOBODY 的组合逻辑。不设对参数,curl_getinfo($ch, CURLINFO_EFFECTIVE_URL) 返回的仍是原始短链地址。

立即学习PHP免费学习笔记(深入)”;

  • 必须开启 CURLOPT_FOLLOWLOCATION => true,否则 cURL 不自动跳转
  • CURLOPT_NOBODY => true 可跳过响应体下载,提速且省内存(我们只要头里的 Location 或最终 URL)
  • 某些短链服务(如微博微信)会返回 302 但禁用跨域跳转,或加了反爬 headers,此时需补 CURLOPT_USERAGENTCURLOPT_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,但那就是另一回事了。

text=ZqhQzanResources