用js的生成a标签下载文件,同时设置请求头
2024-01-10 12:11:05
在 JavaScript 中使用?<a>
?标签下载文件时,直接通过?<a>
?标签的点击事件触发下载,是无法设置请求头的,因为这是一个简单的 GET 请求。如果你需要设置请求头,通常会使用 XMLHttpRequest 或 Fetch API 进行更复杂的请求。
以下是使用 Fetch API 的例子,其中可以设置请求头:
// 创建一个点击事件触发下载
function downloadFile() {
// 文件下载地址
const fileUrl = 'https://example.com/path/to/file';
// 设置请求头
const headers = new Headers();
headers.append('Authorization', 'Bearer YourAccessToken'); // 设置授权头,替换YourAccessToken为实际的访问令牌
// 发起 Fetch 请求
fetch(fileUrl, {
method: 'GET',
headers: headers,
})
.then(response => response.blob())
.then(blob => {
// 创建一个虚拟的链接元素,模拟点击下载
const link = document.createElement('a');
link.href = window.URL.createObjectURL(blob);
link.download = 'filename.ext'; // 设置下载文件名,替换filename.ext为实际的文件名和扩展名
document.body.appendChild(link);
// 模拟点击
link.click();
// 移除虚拟链接元素
document.body.removeChild(link);
})
.catch(error => console.error('下载失败:', error));
}
// 触发下载
downloadFile();
文章来源:https://blog.csdn.net/qq_59747594/article/details/135496763
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!