通过a标签下载文件,不能下载原因

本文介绍了一种在网页中使用含有中文的链接下载文件时遇到的问题及解决方案。具体表现为使用某些浏览器版本时,中文参数会导致文件无法正常下载。通过将中文参数进行URL编码转码,实现了跨浏览器兼容的下载功能。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >


<a href="../api/v1/file/downloadTemplate?templateFileName=sampleExcel.xls&downloadFileName=Excel填写实例.xls" class="layui-btn" style="color:white">Excel填写实例</a>

<a href="../api/v1/file/downloadTemplate?templateFileName=sampleFrame.xls&downloadFileName=Excel模板.xls" class="layui-btn" style="color:white">Excel模板</a>


我点击下载文件的时,能完整下载,但是有个同事使用的360 9.0版本不能正常,最后找到原因。

原因:a标签中参数中带有中文,导致不能正常下载

解决方案:

将中文进行转码

<a href="#" onclick="downloadFile('sampleExcel.xls','Excel填写实例.xls')" class="layui-btn" style="color:white">Excel填写实例</a>
<a href="#" onclick="downloadFile('sampleFrame.xls','Excel模板.xls')" class="layui-btn" style="color:white">Excel模板</a>

function downloadFile(fileName,downloadName){
fileName=encodeURI(encodeURI(fileName));
downloadName=encodeURI(encodeURI(downloadName));

window.location.href='../api/v1/file/downloadTemplate?templateFileName='+fileName+'&downloadFileName='+downloadName;

}



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值