使用js下载文件的各项方式

  • 时间:2021-03-20 20:45 作者:喆哲 来源: 阅读:536
  • 扫一扫,手机访问
摘要:js下载的本质其实无非是让浏览器接收一个流文件,而一般情况下前台下载功能实现直接即可以使用html里面有专门下载标签,各项属性配一下就好了,但是有时候需要基于反爬虫、安全方面的考虑或者者需求上的下载触发,是一个未知的结果等等,这个时候就需要js来解决了。最近也遇到了相似的问题,写个参考集合记录一下直接

js下载的本质其实无非是让浏览器接收一个流文件,而一般情况下前台下载功能实现直接即可以使用html里面有专门下载标签,各项属性配一下就好了,但是有时候需要基于反爬虫、安全方面的考虑或者者需求上的下载触发,是一个未知的结果等等,这个时候就需要js来解决了。最近也遇到了相似的问题,写个参考集合记录一下

  • 直接打开的方式
var url = "https://xxxxx.txt" // 下载地址window.open(url);
  • 本地
window.location.href =  "https://xxxxx.txt" 
  • 创立一个form下载,提交表单的方式
var url = "https://xxxxx.txt" // 下载地址var params  = '123' // 参数  // 创立form表单var formHtml = "<form method='post' style='display:none' id='formDownId' action='"+ url +">" + "<input type='hidden' value='" + params + "'></form>"var initHtml = document.createElement("div")initHtml.innerHTML = formHtml// 将form表单放入指定位置document.body.appendChild(initHtml)//操作dom,下载文件document.getElementById("formDownId").submit()// 下载完成,删除该formdocument.body.removeChild(initHtml)
  • 创立a标签的方式下载
var url =  "https://xxxxx.txt" 1、通过点击const a = document.createElement('a') // 创立a标签a.setAttribute('download', '')a.setAttribute('href', url)a.click() // 执行点击事件2、通过initMouseEvent属性const htmlA = document.createElement('a')htmlA.setAttribute("href", url)htmlA.setAttribute('download', '')const itsArr = document.createEvent('mouseEvents')itsArr.initMouseEvent(    "click",    true,    true,    window,    0,    0,    0,    0,    0,    false,    false,    false,    false,    false,    0,    null)const returnStatus = htmlA.dispatchEvent(itsArr) // 下载结果返回
  • 全部评论(0)
最新发布的资讯信息
【系统环境|】2FA验证器 验证码如何登录(2024-04-01 20:18)
【系统环境|】怎么做才能建设好外贸网站?(2023-12-20 10:05)
【系统环境|数据库】 潮玩宇宙游戏道具收集方法(2023-12-12 16:13)
【系统环境|】遥遥领先!青否数字人直播系统5.0发布,支持真人接管实时驱动!(2023-10-12 17:31)
【系统环境|服务器应用】克隆自己的数字人形象需要几步?(2023-09-20 17:13)
【系统环境|】Tiktok登录教程(2023-02-13 14:17)
【系统环境|】ZORRO佐罗软件安装教程及一键新机使用方法详细简介(2023-02-10 21:56)
【系统环境|】阿里云 centos 云盘扩容命令(2023-01-10 16:35)
【系统环境|】补单系统搭建补单源码搭建(2022-05-18 11:35)
【系统环境|服务器应用】高端显卡再度登上热搜,竟然是因为“断崖式”的降价(2022-04-12 19:47)
手机二维码手机访问领取大礼包
返回顶部