加入收藏 | 设为首页 | 会员中心 | 我要投稿 银川站长网 (https://www.0951zz.com/)- 云通信、基础存储、云上网络、机器学习、视觉智能!
当前位置: 首页 > 综合聚焦 > 编程要点 > 语言 > 正文

一文解决vue如何设置请求头达成页面登录

发布时间:2023-06-09 11:04:30 所属栏目:语言 来源:
导读:今天小编跟大家讲解下有关“一文解决vue如何设置请求头实现页面登录”的内容 ,相信小伙伴们对这个话题应该有所关注吧,小编也收集到了相关资料,希望小伙伴们看了有所帮助。vue设置header后端交互对vue中

今天小编跟大家讲解下有关“一文解决vue如何设置请求头实现页面登录”的内容 ,相信小伙伴们对这个话题应该有所关注吧,小编也收集到了相关资料,希望小伙伴们看了有所帮助。

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中的vue-resource方式交互时,即使不设置contentType:"application/json"也可成功交互;

为什么ajax要求那么严格,原因还不是很清楚;

但是我们可以通过以上方式:每个http请求中加入以下代码,进行设置请求头

headers: {

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

}

全局设置请求头

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

解决问题的主要思路:

1.使得请求头中存在token

网上提供方式:

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

}

},

]

})

这篇关于“一文解决vue如何设置请求头实现页面登录”的文章就介绍到这了,更多相关的内容,小编将为大家输出更多高质量的实用文章!

(编辑:银川站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!