目录
  • vue设置header
    • 后端交互对vue中contentType,和ajax的contentType区别对待
    • 当服务器端需要设置contentType:“application/json”:
    • 全局设置请求头
      • 1.使得请求头中存在token
    • 如何获取真实的token,
    • 扩展:vue 配置公共头部(header)

      vue设置header

      使用vue-resource与vue-cookie实现页面登录,数据存储与后台的数据交互

      后端交互对vue中contentType,和ajax的contentType区别对待

      this.$http
              .post(netUrl, change, {
                headers: {
                  Authorization: "Bearer " + this.$cookies.get("token")
                }
              })
              .then(
                response => {
                  console.log(response.data);
                  if (response.data != null) {
                  }
                },
                response => {
                  console.log("error");
                }
              );

      当服务器端需要设置contentType:“application/json”:

      如果采用的是传统的$.ajax方式进行交互时设置contentType:"application/json;charset=UTF-8"也会导致服务器访问不成功必须严格设置为contentType:“application/json”;

      通过vue如何设置header

      当使用vue中的vue-resource方式交互时,即使不设置contentType:"application/json"也可成功交互;

      通过vue如何设置header

      为什么ajax要求那么严格,原因还不是很清楚;
      但是我们可以通过以上方式:每个http请求中加入以下代码,进行设置请求头

       headers: {
          Authorization: "Bearer " + this.$cookies.get("token")
        }

      全局设置请求头

      虽然上述方式可以成功的设置请求头,但是每个请求都设置显得繁琐,而从网上查找解决方案始终没有成功解决
      解决问题的主要思路:

      1.使得请求头中存在token

      通过vue如何设置header

      网上提供方式:

      Vue.http.interceptors.push((request, next) => {
            // ...
            // 请求发送前的处理逻辑
           request.beforeSend = function() {
                   request.headers['token'] = “token”;
           }
        next((response) => {
            // ...
            // 请求发送后的处理逻辑
            // ...
            // 根据请求的状态,response参数会返回给successCallback或errorCallback
            return response
        })

      测试后发现用以上拦截器的方式不可行,查到网上有说可以尝试

      request.headers.set('token', "Bearer ")

      方式,但是测试后发现仍行不通,通过各种尝试最后发现是去除request.beforeSend直接设置皆可以

      Vue.http.interceptors.push((request, next) => {
        // 请求发送前的处理逻辑
        request.headers.set('token', "Bearer ")
        next((response) => {
          // 请求发送后的处理逻辑
          // 根据请求的状态,response参数会返回给successCallback或errorCallback
          return response
        })
      })

      如何获取真实的token,

      因为全局设置是在main.js中,而token是在登录后才存储下来的能否获取到真实值
      1.确保你的token确实存在
      2.正常程序中通过this.$cookies.get(“token”)可以获取token的值,因为对vue的认知不够深,不知道在入口文件处如何获取token值,通过多次测试获取解决方案

      import Vue from 'vue'
      import VueCookies from 'vue-cookies'
      Vue.use(VueCookies);
      Vue.http.interceptors.push((request, next) => {
        // 请求发送前的处理逻辑
        request.headers.set('Authorization', "Bearer " + VueCookies.get("token"))
        next((response) => {
          // 请求发送后的处理逻辑
          // 根据请求的状态,response参数会返回给successCallback或errorCallback
          return response
        })
      })

      扩展:vue 配置公共头部(header)

      需求:整个项目;每个项目都有头部 但是内容不一样;这种情况我们可以考虑在app.vue中创建公共头部;

      App.vue

      <template>
        	<div id="app">
      	    <div class="header" v-if="isShowHeader" id="headers">
                      <span class="title-info">
                              {{headerTitle}}
                       </span> 
      	     </div>
      	</div>
      </template>
      <script>
      import { mapState } from "vuex";
      import home from "../src/components/home";
       
      export default {
        name: "App",
        data() {
          return {
       
          };
        },
        computed: {
          // 存储到store状态管理中
          ...mapState({
            headerTitle: state => state.$vux.headerTitle,
          })
        },
       
      };
      </script>

      store.js

          import Vue from 'vue'
          import Vuex from 'vuex'
       
          Vue.use(Vuex)
          const store = new Vuex.Store({  })
          store.registerModule('$vux', { // 名字自己定义
              state: {//设置属性
                  headerTitle:'',
              },
              getters:{ // getters 用来获取sate里面存储的数据
       
              },
               mutations: {//更改属性的状态//返回来会有两个状态一个是上面的state,还有一个是返回来的状态(形参),返回之后将我们请求回来的数据赋给state
                       getHeaderTitle(state, obj) {
                      state.headerTitle = obj.headerTitle
                  },
              }
       
          export default store

      main.js

      //全局配置
      import Vue from "vue";
      import App from "./App";
      import router from "./router";
       
        store.commit("getHeaderTitle", { headerTitle: to.meta.title });

      router.js

      import Vue from 'vue'
      import Router from 'vue-router'
      Vue.use(Router)
       
      export default new Router({
        // mode: "history",
        linkActiveClass: "on",
           routes: [
              {
                path: "/business",
                name: "business",
                component: business,
                meta: {
                  title: "粤警监管", // 添加该字段,表示进入这个路由是需要登录的
                  keepAlive: true
                }
              },
          ]
      })
      声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。