node与vue结合的前后端分离跨域问题
第一点:node作为服务端提供数据接口,vue使用axios访问接口,
安装axios
npm install axios --save
安装完成后在main.js中增加一下配置:
import axios from 'axios';
axios.defaults.withCredentials=true
Vue.prototype.$axios = axios;
main.js全部配置如下:
import Vue from 'vue'
import App from './App'
import router from './router' import axios from 'axios';
axios.defaults.withCredentials=true;
Vue.prototype.$axios = axios;
Vue.config.productionTip = false /* eslint-disable no-new */
new Vue({
el: '#app',
router,
template: '<App/>',
components: { App }
})
withCredentials默认是false,意思就是不携带cookie信息,那就让它为true,我是全局性配置的,就是main.js中的这句话:
axios.defaults.withCredentials=true;
得到数据有两种方式:
第一种Get请求,写法为
(1)不传递参数
this.$axios.get("远程服务地址URL",{
withCredentials : true//可以带cookie的认证
}).then(function(res){
//对返回的数据res进行处理的逻辑
})
(2)传递参数 需要params
this.$axios.get("远程服务地址URL",params:{
key1:value1
},{
withCredentials : true//可以带cookie的认证
}).then(function(res){
/对返回的数据res进行处理的逻辑
})
node后台接受访问获取参数的方式为:query
router.get('/addressList', function (req, res, next) {
var key1= req.query.key1;
User.findOne({key1: key1}, function (err, doc) {
if (err) {
res.json({
status: "",
msg: err.message,
result: ''
});
} else {
res.json({
status: "",
msg: '',
result: {
})
}
})
});
第二种Post请求:此处一定要对传递的参数进行一次转型,否则报错,使用插件qs(自身携带,引用即可)需要使用的地方使用import直接导入 import qs from 'qs'
this.$axios.post("远程URL", qs.stringify({ke12:value2},{
withCredentials : true
})).then(function(res){
//对返回的数据res进行处理的逻辑
})
node后台获取值为:body
router.post('/delAddress', function (req, res, next) {
var key1= req.body.key1;
});
以上是属于客户端的针对可以访问远程的配置,要想成功还需服务端的配置,共同配合使用,否则无效任然报错。
在服务端我们需要在app.js中全局配置
//设置跨域访问
var express=require('express')
var app=express()
app.all('*', function (req, res, next) {
res.header('Access-Control-Allow-Headers', 'Content-Type, Content-Length, Authorization, Accept, X-Requested-With , yourHeaderFeild');
res.header('Access-Control-Allow-Methods', 'PUT, POST, GET, DELETE, OPTIONS');
res.header("Access-Control-Allow-Credentials", "true");
res.header("Access-Control-Allow-Origin", "此处是你的客户端的Url");
if (req.method == 'OPTIONS') {
/*让options请求快速返回*/
res.send();
}
else {
next();
}
});
需要让axios请求携带cookie,也就是认证信息,于是在后台拦截器中(app.js中),增加了一个需要认证信息的header:
res.header("Access-Control-Allow-Credentials", "true");
然后再次在浏览器中测试,发现浏览器提示,当Access-Control-Allow-Credentials设为true的时候,Access-Control-Allow-Origin不能设为星号,既然不让我设为星号,我就改成前端项目的配置
res.header("Access-Control-Allow-Origin", http://127.0.0.1:8081);
注意:使用顺序,请按照上述的代码顺序依次引入,否则任有可能报错。上述的全局配置中其实会出现异步请求问题,也就是"重复作出响应"问题----Error: Can't set headers after they are sent
所以配置应改成:
app.all('*', function (req, res, next) {
res.header('Access-Control-Allow-Headers', 'Content-Type, Content-Length, Authorization, Accept, X-Requested-With , yourHeaderFeild');
res.header('Access-Control-Allow-Methods', 'PUT, POST, GET, DELETE, OPTIONS');
res.header("Access-Control-Allow-Credentials", "true");
res.header("Access-Control-Allow-Origin", "http://localhost:8081");//配置客户端 localhost与127.0.0.1是一个意思
if (req.method == 'OPTIONS') {
/*让options请求快速返回*/
res.send();
}
else {
/*防止异步造成多次响应,出现错误*/
var _send = res.send;
var sent = false;
res.send = function (data) {
if (sent) return;
_send.bind(res)(data);
sent = true;
};
next();
}
});
node与vue结合的前后端分离跨域问题的更多相关文章
- nginx-springboot-vue前后端分离跨域配置
nginx-springboot-vue前后端分离跨域配置 引言 接着上篇--简单的springboot-vue前后端分离登录Session拦截的demo,其中跨域是通过springboot后端全局设 ...
- Django前后端分离跨域请求问题
一.问题背景 之前使用django+vue进行前后端分离碰到跨域请求问题,跨域(域名或者端口不同)请求问题的本质是由于浏览器的同源策略导致的,当请求的响应不是处于同一个域名和端口下,浏览器不会接受响应 ...
- nginx反向代理实现前后端分离&跨域问题
1.代理和跨域 1.1 正向代理 1)用户希望代理服务器帮助其和要访问服务器之间实现通信,需要: a.用户IP报文的目的IP=代理服务器IP: b.用户报文端口号=代理服务器监听端口号: c.HTTP ...
- 前后端分离跨域 关于前后端分离开发环境下的跨域访问问题(angular proxy=>nginx )
前后端分离后遇到了跨域访问的问题: angular1中使用proxy很麻烦,最后还是失败结束:最后总结3种方法如下: 本人使用的第一种方法,只是开发环境下使用很方便! 1:禁掉谷歌的安全策略(Turn ...
- Beego和Vue的前后端分离跨域问题处理
VUE封装的请求头(注意请求头,跨域要用到) 路径 utils/mereq.js import request from '@/utils/request' import qs from 'qs' e ...
- 关于.Net Core 前后端分离跨域请求时 ajax并发请求导致部分无法通过验证解决办法。
项目中有这样一个页面.页面加载的时候会同时并发6个ajax请求去后端请求下拉框. 这样会导致每次都有1~2个“浏览器预请求”不通过. 浏览器为什么会自动发送“预请求”?请看以面连接 https://b ...
- nginx配置反向代理解决前后端分离跨域问题
摘自<AngularJS深度剖析与最佳实践>P132 nginx配置文件如下: server { listen ; server_name your.domain.name; locati ...
- spring boot 过滤器 前后端分离跨域sessionId不一致
import org.springframework.stereotype.Component; import javax.servlet.*; import javax.servlet.http ...
- springboot前后端分离跨域
@Configurationpublic class CrossConfig implements WebMvcConfigurer { @Override public void addCorsMa ...
随机推荐
- JNI_Z
1. ZC: 用到 VC6 ... http://blog.csdn.net/jiangwei0910410003/article/details/17465085 http://blog.csdn. ...
- JavaScript 对时间日期格式化
JavaScript 对时间日期格式化 // 对Date的扩展,将 Date 转化为指定格式的String // 月(M).日(d).小时(h).分(m).秒(s).季度(q) 可以用 1-2 个占位 ...
- Struts2学习(1)
struts2概述 1.struts2框架应用javaee三层结构中web层框架. 2.strut2框架在struts1和webwork基础之上发展全新的框架. 3.struts2解决的问题: 4.版 ...
- if 条件判断 和 判断总结---shell脚本
本文主要介绍了Shell脚本IF条件判断和判断条件总结,本文先是给出了IF条件判断的语法,然后给出了常用的判断条件总结,需要的朋友可以参考下. 前言: 无论什么编程语言都离不开条件判断.SHELL也不 ...
- 批处理BAT(一)
批处理 全盘根目录下查找文件夹并删除(1)@echo offfor %%a in (C D E F G H) DO (cd\if exist "%%a:\123\" rd /s / ...
- IT从业人员必看的10个论坛(转)
IT方面的论坛太多了,有综合,有专业,有行业,在各个论坛里混了几年,体会颇深,以前是论坛哪里人多,往哪里去,新浪论坛,网易是经常去的,人多啊,好几十万,去了以后才发现没有意思,没有共同的语言,于是逛专 ...
- 20165210 Java第五周学习总结
20165210 Java第五周学习总结 教材学习内容 - 第七章学习总结 内部类: 内部类的外嵌类的成员变量在内部类中仍然有效,内部类中的方法也可以调用外嵌类中的方法. 内部类的类体中不可以声明类变 ...
- np.unique 的实现
1. 简单实现 import numpy as np def unique(ar): perm = ar.argsort() aux = ar[perm] flag = np.concatenate( ...
- awk指令的使用
awk是一个强大的文本分析工具,相对于grep的查找,sed的编辑,awk在其对数据分析并生成报告时,显得尤为强大 awk工作流程是这样的:读入有'\n'换行符分割的一条记录,然后将记录按指定的域分隔 ...
- tests
test