NodeJS后台服务进行跨域处理

定义一个中间件来添加响应标头,然后在处理app.get(或post等)之前使用 

只要将下面的代码;放在处理路由之前就行 

设置允许所有域名跨域:

var app = express();
//设置跨域访问
app.all('*', function(req, response, next) {

//设置允许跨域的域名,*代表允许任意域名跨域
response.header("Access-Control-Allow-Origin", "*");
//允许的header类型
response.header("Access-Control-Allow-Headers", "X-Requested-With");
//跨域允许的请求方式
response.header("Access-Control-Allow-Methods","PUT,POST,GET,DELETE,OPTIONS");
//设置响应头信息
response.header("X-Powered-By",' 3.2.1')
response.header("Content-Type", "application/json;charset=utf-8");




next();
});

设置允许指定域名“http://www.XXX.com”跨域:

 res.header("Access-Control-Allow-Origin","http://www.XXX.com");

设置允许多个域名跨域:

 if( req.headers.origin.toLowerCase() == "http://www.xxxx.com"  ||  req.headers.origin.toLowerCase() =="http://127.0.0.1" ) {
       //设置允许跨域的域名,
       res.header("Access-Control-Allow-Origin", req.headers.origin);
  }

如果允许的域名较多,可以将允许跨域的域名放到数组当中:

 

var orginList=[
"http://www.xxx.com",
"http://www.alibaba.com",
"http://www.qq.com",
"http://www.baidu.com"
]
if(orginList.includes(req.headers.origin.toLowerCase())){
//设置允许跨域的域名,*代表允许任意域名跨域
res.header("Access-Control-Allow-Origin",req.headers.origin);
}

 

 

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值