axios发送post请求变成了options请求返回403
时间: 2023-09-27 08:03:58 浏览: 209
解决在Vue中使用axios POST请求变成OPTIONS的问题
5星 · 资源好评率100%
当使用axios发送跨域的POST请求时,浏览器会先发送一个OPTIONS请求进行预检,以确保服务端支持跨域请求。预检成功后才会发送真正的POST请求。如果OPTIONS请求返回的状态码不是200,那么浏览器就会阻止POST请求的发送,从而导致403错误。
出现这种情况的原因可能是服务端没有正确的处理OPTIONS请求。你可以尝试在服务端添加对OPTIONS请求的处理,返回200状态码,以解决这个问题。如果你使用的是Node.js,可以使用以下代码来处理OPTIONS请求:
```
app.use(function(req, res, next) {
res.header("Access-Control-Allow-Origin", "*");
res.header("Access-Control-Allow-Headers", "Origin, X-Requested-With, Content-Type, Accept");
res.header('Access-Control-Allow-Methods', 'PUT,POST,GET,DELETE,OPTIONS');
if (req.method === 'OPTIONS') {
res.sendStatus(200);
} else {
next();
}
});
```
这段代码会在所有请求之前加入一个中间件,对所有类型的请求进行CORS处理。如果请求类型是OPTIONS,直接返回200状态码,否则继续执行后续的请求处理。
阅读全文