window.location.href下载中文名称文件报错

导出文件, 当文件是中文的时候, 有时候浏览器会自动转码,导致服务器上找不到这个文件了而报错。
比如:
/home/data/李四.xls 存在与服务器上, 通过window.location.href=file_url后,
/home/data/%E6%9D%8E%E5%9B%9B.xls 浏览器自动转了找不到文件了404
在这里插入图片描述
开始以为是前端后台的编码格式不一致导致传输数据过程中变了,就想着用URLcode后台加密前台解密。但最终发现在页面上即使写死一个中文名称文件名也是一样的结果。也尝试了window.open(),最后还是放弃了window.location.href,换了一种写法。
html里面新增一行

<!--  download  是H5的新特点, 没有是点击查看,有点击则是下载-->
<a download href="" id="download_url" style="display: none"></a>

js如下

$("#download_url").attr("href","${context_root}"+res.file_url); // 下载文件地址
$("#download_url").attr("download",res.file_name);  // 下载文件名称
document.getElementById("download_url").click(); // 点击

原理是后台生成的英文数字文件名,这样下载是不报错的(包括window.location.href也不报错)。然后把url给a标签的href属性赋值然后模拟点击a标签实现下载,并且重命名了下载后的文件名。

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值