解决NodeJS+Express模块的跨域访问控制问题
在一个项目上想用NodeJS,在前端的JS(http://localhost/xxx)中ajax访问后端RestAPI(http://localhost:3000/….)时(Chrome)报错
在一个项目上想用NodeJS,在前端的JS(http://localhost/xxx)中ajax访问后端RestAPI(http://localhost:3000/….)时(Chrome)报错:
XMLHttpRequest cannot load http://localhost:3000/auth/xxx/xxx. Origin http://localhost is not allowed by Access-Control-Allow-Origin.
解决代码:
方案一:
var express = require('express'); var app = express(); //设置跨域访问 app.all('*', 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"); res.header("X-Powered-By",' 3.2.1') res.header("Content-Type", "application/json;charset=utf-8"); next(); }); app.get('/auth/:id/:password', function(req, res) { res.send({id:req.params.id, name: req.params.password}); }); app.listen(3000); console.log('Listening on port 3000...');
方案二:
var express = require('express'); var app = express(); app.get('/auth/:id/:password', function(req, res) { res.header("Access-Control-Allow-Origin", "*"); //设置跨域访问 res.send({id:req.params.id, name: req.params.password}); }); app.listen(3000); console.log('Listening on port 3000...');
很赞哦! ( 0
)
相关文章
- 第10天 cookie与session— session插件开发
- 第10天 cookie与session— session插件分析
- 第9天response 响应渲染 —动态渲染实例
- 第9天response 响应渲染 —动态渲染插件开发
- 第9天response 响应渲染 —动态渲染插件分析
- 第9天response 响应渲染 —download插件开发
- 第9天response 响应渲染 —跳转插件开发
- 第9天response 响应渲染 —文本渲染插件开发
- 第8天 二进制文件上传—其它实现方式
- 第8天 二进制文件上传—原理解析
- 第8天 二进制文件上传—升级post.js插件
- 第8天 二进制文件上传—上传实例