nodejs处理options预检问题

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,首字母大写,后端接受的请求头也必须一致:

否则就会一直预检不通过 

可以看到,此处预检已通过处理 

猜你喜欢

转载自blog.csdn.net/weixin_44510655/article/details/128007358