PHP获取短链真实URL后,用file_put_contents()写入带时间戳的txt文件,或用fputcsv()生成含BOM的CSV;直接下载则需header()设置类型与附件名,再通过php://output输出,关键要正确配置cURL跳转参数。
.txt 文件PHP 本身不自动“下载”或“导出”,所谓“保存为 txt”,本质是:获取到真实 URL 后,用 file_put_contents() 写入本地文件,或用 header() 强制浏览器下载。最稳妥的做法是先写入服务器磁盘,再提供下载链接。
./outputs/),否则 file_put_contents() 会静默失败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']),之后每行一个数组\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;
短链还原核心在 HTTP 重定向跟踪,但很多人只调 curl_exec() 却忽略 CURLOPT_FOLLOWLOCATION 和
CURLOPT_NOBODY 的组合逻辑。不设对参数,curl_getinfo($ch, CURLINFO_EFFECTIVE_URL) 返回的仍是原始短链地址。
CURLOPT_FOLLOWLOCATION => true,否则 cURL 不自动跳转CURLOPT_NOBODY => true 可跳过响应体下载,提速且省内存(我们只要头里的 Location 或最终 URL)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,但那就是另一回事了。
# php
# linux
# excel
# js
# 微信
# 编码
# 浏览器
# app
# 微博
# curl
# 中文乱码
# csv
# ai
# 跨域
# echo
# print
# date
# timestamp
# fopen
# fclose
# filter_var
相关文章:
如何有效防御Web建站篡改攻击?
如何在IIS7上新建站点并设置安全权限?
电商平台网站制作流程,电商网站如何制作?
如何正确下载安装西数主机建站助手?
如何在IIS服务器上快速部署高效网站?
建站之星×万网:智能建站系统+自助建站平台一键生成
学校为何禁止电信移动建设网站?
专业的网站制作设计是什么,如何制作一个企业网站,建设网站的基本步骤有哪些?
佛山网站制作系统,佛山企业变更地址网上办理步骤?
惠州网站建设制作推广,惠州市华视达文化传媒有限公司怎么样?
Python如何创建带属性的XML节点
上海网站制作开发公司,上海买房比较好的网站有哪些?
已有域名能否直接搭建网站?
如何选择PHP开源工具快速搭建网站?
郑州企业网站制作公司,郑州招聘网站有哪些?
官网自助建站系统:SEO优化+多语言支持,快速搭建专业网站
如何快速查询网站的真实建站时间?
香港网站服务器数量如何影响SEO优化效果?
广平建站公司哪家专业可靠?如何选择?
平台云上自助建站如何快速打造专业网站?
如何用wdcp快速搭建高效网站?
如何在建站宝盒中设置产品搜索功能?
小视频制作网站有哪些,有什么看国内小视频的网站,求推荐?
我的世界制作壁纸网站下载,手机怎么换我的世界壁纸?
如何快速搭建响应式可视化网站?
制作网站建设的公司有哪些,网站建设比较好的公司都有哪些?
建站之星logo尺寸如何设置最合适?
头像制作网站在线观看,除了站酷,还有哪些比较好的设计网站?
视频网站制作教程,怎么样制作优酷网的小视频?
网站制作模板下载什么软件,ppt模板免费下载网站?
建站之星展会模版如何一键下载生成?
如何在腾讯云服务器上快速搭建个人网站?
北京制作网站的公司排名,北京三快科技有限公司是做什么?北京三快科技?
教学网站制作软件,学习*后期制作的网站有哪些?
武汉网站制作费用多少,在武汉武昌,建面100平方左右的房子,想装暖气片,费用大概是多少啊?
可靠的网站设计制作软件,做网站设计需要什么样的电脑配置?
如何高效配置IIS服务器搭建网站?
如何配置FTP站点权限与安全设置?
建站主机服务器选型指南与性能优化方案解析
建站主机助手选型指南:2025年热门推荐与高效部署技巧
如何用虚拟主机快速搭建网站?详细步骤解析
制作网站的网址是什么,请问后缀为.com和.com.cn还有.cn的这三种网站是分别是什么类型的网站?
如何通过.red域名打造高辨识度品牌网站?
如何选择最佳自助建站系统?快速指南解析优劣
制作表格网站有哪些,线上表格怎么弄?
建站之星在线客服如何快速接入解答?
网站好制作吗知乎,网站开发好学吗?有什么技巧?
建站主机数据库如何配置才能提升网站性能?
公司网站制作费用多少,为公司建立一个网站需要哪些费用?
北京网站制作的公司有哪些,北京白云观官方网站?
*请认真填写需求信息,我们会在24小时内与您取得联系。