js解决跨域下载文件
之前用的是a标签的方式,同源是没有问题的,但一跨域就不行了,试了其它方法,不是报跨域错误,就是在当前页面打开文件,体验相当不好。
data = data.replace(/\\/g, '/'); var aLink = document.createElement('a'); aLink.download = data.split('/')[data.split('/').length - 1]; aLink.href = data; aLink.click();
最终解决方案:
/** * 获取页面文件名 * @param url 文件url */ function downloadUrlFile(url) { url= url.replace(/\\/g, '/'); const xhr = new XMLHttpRequest(); xhr.open('GET', url, true); xhr.responseType = 'blob'; //xhr.setRequestHeader('Authorization', 'Basic a2VybWl0Omtlcm1pdA=='); xhr.onload = () => { if (xhr.status === 200) { // 获取文件blob数据并保存 var fileName = getFileName(url); saveAs(xhr.response, fileName); } }; xhr.send(); } /** * URL方式保存文件到本地 * @param data 文件的blob数据 * @param name 文件名 */ function saveAs(data, name) { var urlObject = window.URL || window.webkitURL || window; var export_blob = new Blob([data]); var save_link = document.createElementNS('http://www.w3.org/1999/xhtml', 'a') save_link.href = urlObject.createObjectURL(export_blob); save_link.download = name; save_link.click(); } /** * 根据文件url获取文件名 * @param url 文件url */ function getFileName(url) { var num = url.lastIndexOf('/')+1 var fileName = url.substring(num) //把参数和文件名分割开 fileName = decodeURI(fileName.split("?")[0]); return fileName; }
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· AI技术革命,工作效率10个最佳AI工具