前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >node与vue结合的前后端分离跨域问题

node与vue结合的前后端分离跨域问题

作者头像
wfaceboss
发布2019-04-08 10:49:58
1.1K0
发布2019-04-08 10:49:58
举报
文章被收录于专栏:wfacebosswfaceboss

第一点:node作为服务端提供数据接口,vue使用axios访问接口,

安装axios

代码语言:javascript
复制
npm install axios --save

安装完成后在main.js中增加一下配置:

代码语言:javascript
复制
import axios from 'axios';
axios.defaults.withCredentials=true

main.js全部配置如下:

代码语言:javascript
复制
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中的这句话:

代码语言:javascript
复制
axios.defaults.withCredentials=true;

得到数据有两种方式:

第一种Get请求,写法为

(1)不传递参数

代码语言:javascript
复制
this.$axios.get("远程服务地址URL",{
        withCredentials : true//可以带cookie的认证
             }).then(function(res){

                //对返回的数据res进行处理的逻辑
        })

 (2)传递参数 需要params

代码语言:javascript
复制
this.$axios.get("远程服务地址URL",params:{
  key1:value1
},{
   withCredentials : true//可以带cookie的认证
     }).then(function(res){

/对返回的数据res进行处理的逻辑

})

 node后台接受访问获取参数的方式为:query

代码语言:javascript
复制
router.get('/addressList', function (req, res, next) {
   var    key1= req.query.key1;
    User.findOne({key1: key1}, function (err, doc) {
        if (err) {
            res.json({
                status: "1",
                msg: err.message,
                result: ''
            });
        } else {
            res.json({
                status: "0",
                msg: '',
                result: {

            })
        }
    })
});

第二种Post请求:此处一定要对传递的参数进行一次转型,否则报错,使用插件qs(自身携带,引用即可)需要使用的地方使用import直接导入  import  qs from 'qs'

代码语言:javascript
复制
 this.$axios.post("远程URL", qs.stringify({ke12:value2},{
                  withCredentials : true
                })).then(function(res){

               //对返回的数据res进行处理的逻辑
                       })

node后台获取值为:body

代码语言:javascript
复制
router.post('/delAddress', function (req, res, next) {

    var key1= req.body.key1;
   
});

以上是属于客户端的针对可以访问远程的配置,要想成功还需服务端的配置,共同配合使用,否则无效任然报错。

在服务端我们需要在app.js中全局配置

代码语言:javascript
复制
//设置跨域访问
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(200);
    }
    else {
        next();
    }
});

需要让axios请求携带cookie,也就是认证信息,于是在后台拦截器中(app.js中),增加了一个需要认证信息的header:

代码语言:javascript
复制
res.header("Access-Control-Allow-Credentials", "true");

然后再次在浏览器中测试,发现浏览器提示,当Access-Control-Allow-Credentials设为true的时候,Access-Control-Allow-Origin不能设为星号,既然不让我设为星号,我就改成前端项目的配置

代码语言:javascript
复制
res.header("Access-Control-Allow-Origin", http://127.0.0.1:8081);

注意:使用顺序,请按照上述的代码顺序依次引入,否则任有可能报错。上述的全局配置中其实会出现异步请求问题,也就是"重复作出响应"问题----Error: Can't set headers after they are sent

所以配置应改成:

代码语言:javascript
复制
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(200);
    }
    else {
/*防止异步造成多次响应,出现错误*/
        var _send = res.send;
        var sent = false;
        res.send = function (data) {
            if (sent) return;
            _send.bind(res)(data);
            sent = true;
        };
        next();
    }
});
本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2017-11-25 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档