nodejs出现预见的问题主要是由于客户端发起了复杂的请求,处理代码如下:
app.all('*', function (req, res, next) {
// 设置请求头为允许跨域
res.header('Access-Control-Allow-Origin', '*');
// 设置服务器支持的所有头信息字段
res.header('Access-Control-Allow-Headers', 'Content-Type, Content-Length, Authorization, Accept, X-Requested-With , yourHeaderFeild, sessionToken');
// 设置服务器支持的所有跨域请求的方法
res.header('Access-Control-Allow-Methods', 'PUT, POST, GET, DELETE, OPTIONS');
if (req.method.toLowerCase() == 'options') {
res.send(200); // 让options尝试请求快速结束
} else {
next();
}
});
需要注意的是,后端允许的请求字段必须要与前端设置的请求头一致,否则极有可能致使一直Options请求不通过。
以下是前端设置的请求头,以content-type为例:
可以看到,前端设置的 Content-Type,首字母大写,后端接受的请求头也必须一致:
否则就会一直预检不通过
可以看到,此处预检已通过处理