NodeJS配置CORS实现过程详解


Posted in NodeJs onDecember 02, 2020

跨域问题主要在header上下功夫

首先提供一个w3c的header定义 http://www.w3.org/Protocols/rfc2616/rfc2616-sec14.html

再提供一个网友提供的header详解 http://kb.cnblogs.com/page/92320/

这两个有助于帮助大家理解header的类型和作用, 但是遗憾的是跨域相关的两个header属性我都没有找到相关的定义,

下面直接告诉大家 1是Access-Control-Allow-Origin 允许的域 2是Access-Control-Allow-Headers 允许的header类型

第一项可以直接设为* 表示任意 但是第二项不能这样写,在chrome中测试跨域发现报错, 最终的代码看起来是这个样子:

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");
  res.header("Access-Control-Allow-Methods","PUT,POST,GET,DELETE,OPTIONS");
  res.header("X-Powered-By",' 3.2.1')
  if(req.method=="OPTIONS") res.send(200);/*让options请求快速返回*/
  else next();
});

另外有cors模块可以用

CORS需要浏览器和服务器同时支持。目前,所有浏览器都支持该功能,IE浏览器不能低于IE10。

整个CORS通信过程,都是浏览器自动完成,不需要用户参与。对于开发者来说,CORS通信与同源的AJAX通信没有差别,代码完全一样。浏览器一旦发现AJAX请求跨源,就会自动添加一些附加的头信息,有时还会多出一次附加的请求,但用户不会有感觉。

因此,实现CORS通信的关键是服务器。只要服务器实现了CORS接口,就可以跨源通信。

浏览器将CORS请求分成两类:简单请求(simple request)和非简单请求(not-so-simple request)。

只要同时满足以下两大条件,就属于简单请求。

(1) 请求方法是以下三种方法之一:

  • HEAD
  • GET
  • POST

(2)HTTP的头信息不超出以下几种字段:

  • Accept
  • Accept-Language
  • Content-Language
  • Last-Event-ID

Content-Type:只限于三个值application/x-www-form-urlencoded、multipart/form-data、text/plain

这是为了兼容表单(form),因为历史上表单一直可以发出跨域请求。AJAX 的跨域设计就是,只要表单可以发,AJAX 就可以直接发。

凡是不同时满足上面两个条件,就属于非简单请求。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

NodeJs 相关文章推荐
ubuntu下安装nodejs以及升级的办法
May 08 NodeJs
Nodejs中 npm常用命令详解
Jul 04 NodeJs
详解nodeJS中读写文件方法的区别
Mar 06 NodeJs
详解nodejs微信公众号开发——1.接入微信公众号
Apr 10 NodeJs
Nodejs+angularjs结合multiparty实现多图片上传的示例代码
Sep 29 NodeJs
NodeJs通过async/await处理异步的方法
Oct 09 NodeJs
Nodejs下使用gm圆形裁剪并合成图片的示例
Feb 22 NodeJs
Nodejs Express 通过log4js写日志到Logstash(ELK)
Aug 30 NodeJs
nodejs更新package.json中的dependencies依赖到最新版本的方法
Oct 10 NodeJs
nodejs 使用nodejs-websocket模块实现点对点实时通讯
Nov 28 NodeJs
nodejs中实现修改用户路由功能
May 24 NodeJs
5分钟教你用nodeJS手写一个mock数据服务器的方法
Sep 10 NodeJs
如何利用nodejs自动定时发送邮件提醒(超实用)
Dec 01 #NodeJs
nodeJs项目在阿里云的简单部署
Nov 27 #NodeJs
如何利用nodejs实现命令行游戏
Nov 24 #NodeJs
NodeJS模块Buffer原理及使用方法解析
Nov 11 #NodeJs
nodejs中内置模块fs,path常见的用法说明
Nov 07 #NodeJs
Nodejs + sequelize 实现增删改查操作
Nov 07 #NodeJs
nodejs+koa2 实现模仿springMVC框架
Oct 21 #NodeJs
You might like
PHP与SQL注入攻击[二]
2007/04/17 PHP
关于PHP实现异步操作的研究
2013/02/03 PHP
详解cookie验证的php应用的一种SSO解决办法
2017/10/20 PHP
PHP实现微信小程序人脸识别刷脸登录功能
2018/05/24 PHP
微信企业转账之入口类分装php代码
2018/10/01 PHP
jQuery 位置插件
2008/12/25 Javascript
老鱼 浅谈javascript面向对象编程
2010/03/04 Javascript
JavaScript ECMA-262-3 深入解析.第三章.this
2011/09/28 Javascript
jquery实现手机发送验证码的倒计时代码
2014/02/12 Javascript
Jquery遍历checkbox获取选中项value值的方法
2014/02/13 Javascript
php析构函数的具体用法小结
2014/03/11 Javascript
javascript数组去重方法汇总
2015/04/23 Javascript
jquery实现的Accordion折叠面板效果代码
2015/09/02 Javascript
GitHub上一些实用的JavaScript的文件压缩解压缩库推荐
2016/03/13 Javascript
jquery结合html实现中英文页面切换
2016/11/29 Javascript
VueJs监听window.resize方法示例
2018/01/17 Javascript
微信小程序点击图片实现长按预览、保存、识别带参数二维码、转发等功能
2019/07/20 Javascript
Vue-cli打包后部署到子目录下的路径问题说明
2020/09/02 Javascript
[02:11]2016国际邀请赛中国区预选赛全程回顾
2016/07/01 DOTA
Python的内存泄漏及gc模块的使用分析
2014/07/16 Python
为Python的web框架编写前端模版的教程
2015/04/30 Python
Python 爬虫图片简单实现
2017/06/01 Python
python实现n个数中选出m个数的方法
2018/11/13 Python
解决PyCharm不运行脚本,而是运行单元测试的问题
2019/01/17 Python
纯CSS3实现的阴影效果
2014/12/24 HTML / CSS
英国在线药房和在线药剂师:Chemist 4 U
2020/01/05 全球购物
公司营业员的工作总结自我评价
2013/10/05 职场文书
祖国在我心中演讲稿
2014/01/15 职场文书
离婚协议书怎么写2014
2014/09/30 职场文书
先进人物事迹材料
2014/12/29 职场文书
品质保证书格式
2015/02/28 职场文书
自荐信模板大全
2015/03/27 职场文书
项目技术负责人岗位职责
2015/04/13 职场文书
2016年百日安全生产活动总结
2016/04/06 职场文书
股东合作协议书模板2篇
2019/11/05 职场文书
Python实现双向链表
2022/05/25 Python