form表单提交前设置请求头request header及文件下载

需求:想要在form表单submit之前,设置一下请求头。

除了用Ajax发起请求之外,还可以使用FormData来实现,咱不懂就问。

1 问:FormData什么时间出现的?与ajax什么联系?

2 问:FormData使用方法

参考示例:

<form id="testForm">
    <input name="username" />
</form>

js:

let data= new FormData(document.getElementById('testForm'));
let xhrObj = new XMLHttpRequest();
xhrObj.open('POST', url, true);
xhrObj.setRequestHeader('自定义请求头', '值');
xhrObj.onload = function () {
    if (xhrObj.readyState === 4 && xhrObj.status === 200) {
        console.log(xhrObj.responseText);
    } else {
        // 请求错误
    }
};
xhrObj.send(data);

如果请求是一个下载文件(二进制流)的url,除了需要额外设置下responseType之外,还需要添加模拟触发下载的代码:

let data= new FormData(document.getElementById('testForm'));
let xhrObj = new XMLHttpRequest();
xhrObj.open('POST', downloadUrl, true);
xhrObj.setRequestHeader('自定义请求头', '值');
xhrObj.responseType = 'blob';
xhrObj.onload = function () {
    if (xhrObj.readyState === 4 && xhrObj.status === 200) {
		let content= xhrObj.getResponseHeader('Content-Disposition');
		let fileName = content.split(';')[1];
		fileName = decodeURI(fileName.split('=')[1]);
		let respObj= xhrObj.response;
		let downloadLink = document.createElement('a');
		downloadLink.href = URL.createObjectURL(respObj);
		downloadLink.download = fileName;
		downloadLink.click();
    } else {
        // 请求错误
    }
};
xhrObj.send(data);

HTML 表单中,设置 POST 请求头通常不需要直接在表单元素上进行操作,因为浏览器会默认发送 GET 或 POST 请求。但是,如果你想在发送表单数据到后端服务时添加自定义的请求头信息,可以借助 JavaScript 或者后端编程语言来实现。 **JavaScript 示例**(端): ```javascript var xhr = new XMLHttpRequest(); xhr.open('POST', 'your-url-here', true); xhr.setRequestHeader('Content-Type', 'application/json'); // 设置请求头 Content-Type 为 json xhr.setRequestHeader('Authorization', 'Bearer your-token'); // 添加其他自定义头信息 // 发送表单数据 xhr.send(JSON.stringify({ key: value, ... // 表单数据 })); ``` 在这个例子中,我们使用了 `XMLHttpRequest` 对象手动构造了一个 POST 请求,并设置了 `setRequestHeader` 方法来添加请求头。 **后端示例**(Node.js 使用 Express为例): ```javascript const express = require('express'); const app = express(); app.use(express.json()); // 配置中间件来解析 JSON 格式请求体 app.post('/your-endpoint', function(req, res) { const token = req.headers.authorization; // 获取 Authorization 请求头 console.log('Received POST request with custom header:', token); // 处理请求... }); ``` 在后端,你可以通过 `req.headers` 对象访问到来的请求头。 需要注意的是,某些敏感信息(如 Token)可能不适合放在请求头里,而是应该作为 URL 参数或者通过某种加密方式放置在请求体中。同时,不是所有后端服务器都会接受来自客户端的所有请求头,所以最好查阅服务器文档了解支持哪些头部字段。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

wsdhla

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值