vue在响应头response中获取自定义headers操作


Posted in Javascript onJuly 24, 2020

日常开发,我们可能会为了安全问题,保证第三方无法通过伪造返回报文欺骗前端,需要在返回报文中添加自定义参数,用于验证身份,后端添加自定义参数,前端校验自定义参数通过后才会执行相应的操作。

系统为了安全会去掉自定义头,如果不做任何处理,前端无法通过javascript访问自定义头,所以需要在接口返回中添加这样的操作。

response['Cookie'] ='13231231231' #自定义头

添加后接口返回信息如以下截图:

vue在响应头response中获取自定义headers操作

控制台打印headers信息如以下截图:

vue在响应头response中获取自定义headers操作

要正确打印需要在接口返回中设置以下信息:

response['Access-Control-Expose-Headers'] = "Cookie" #Cookie为自定义头的key

设置完后,打印截图如下:

vue在响应头response中获取自定义headers操作

VUE前端获取代码如下:

this.$http.post("/xx/xxx", {
   tel: '12345678901',
   code: '123456'
 }).then(res => {
   if (res.data.returnCode == 0) {
     if (res.data.bean) {
      let cookie = res.headers.cookie;
      console.log(cookie);
      //校验自定义headers,通过则进行下一步操作
     } else {
      this.$Message.error("失败");
     }
   } else {
     this.$Message.error(res.data.returnMessage);
   }
 }).catch(function(error) {
   console.log(error);
 });

按照上面的操作,就可以解决欺骗前端的安全问题。

补充知识:vue前端利用localStorage存储token值并放到请求头headers实例

之前在关于登录接口的一篇博客里,我有提到过token,在这篇博客里我会介绍token在前端如何存取,同时把它放在请求头里获取数据。

1、关于token

为什么要用Token:

Token是在客户端频繁向服务端请求数据,服务端频繁的去数据库查询用户名和密码并进行对比,判断用户名和密码正确与否,并作出相应提示,在这样的背景下,Token便应运而生。

Token的定义:

Token是服务端生成的一串字符串,以作客户端进行请求的一个令牌,当第一次登录后,服务器生成一个Token便将此Token返回给客户端,以后客户端只需带上这个Token前来请求数据即可,无需再次带上用户名和密码。

使用Token的目的:

Token的目的是为了减轻服务器的压力,减少频繁的查询数据库,使服务器更加健壮。

Token 的优点:

扩展性更强,也更安全点,非常适合用在 Web 应用或者移动应用上。Token 的中文有人翻译成 “令牌”,我觉得挺好,意思就是,你拿着这个令牌,才能过一些关卡。

2、token使用要达到的效果

首先来看后端给的接口文档,在关于登录和登出这两个接口里面,后端说他会给你一个token值,然后呢你要根据这个token获取用户的信息,比如用户名、用户订单、用户收藏啥啥啥的。

vue在响应头response中获取自定义headers操作

接着我们在postman里面试一试,有了这个token值后台会返回什么数据。由于一通百通这里我们就只看登录页面。看下图,返回给我们的是用户的一些基本信息。

vue在响应头response中获取自定义headers操作

注意点来了!这个token值我们是在登录也就是login.vue这个页面从后端获得的。但是我们利用这个token值获取用户信息是在另一个页面,看下面两张图我们可能更能理解:

vue在响应头response中获取自定义headers操作

也就是说我们在登录页面获取token,在“我的”页面通过token请求用户名放到对应位置。

3、利用localStorage存取token实例

登录按钮的js:

handleLogin() {
   this.$axios({
    method: 'post',
    url: '/api/v1/login',
    headers: {
      'Content-Type': "application/json;charset=UTF-8",
    },
    data: {
     name: this.loginForm.username,
     password: this.loginForm.password
    }
   })
   .then(res=>{          //请求成功后执行函数
    if(res.data.code === 0){
     //利用localstorage存储到本地
     localStorage.setItem("token",res.data.data.token)
     this.$router.push('/me') //登录验证成功路由实现跳转
     console.log("登录成功")
    }else{
     console.log("登录失败")
    }
   })
   .catch(err=>{          //请求错误后执行函
    console.log("请求错误")
   })
  },

在这个登录页面我们主要是通过localstorage来把token值存到本地。

核心代码:

localStorage.setItem("token",res.data.data.token)

//表示把res.data.data.token这个value存储到本地的“token”这个key里面

这里的res.data.data.token,一定要注意是否有两个data。从下图可以看到,res.data是指返回的所有数据,因此再有一个data表示data里边的数据,token就在里边了。

vue在响应头response中获取自定义headers操作

- me.vue页面取出token值并请求用户名js代码:

export default {
  data: function () {
      return {
       name:'',
       token:''
      }
  },
  
  created(){
   //页面加载时就从本地通过localstorage获取存储的token值
    this.token = localStorage.getItem('token')
  },
   mounted() {
    this.$axios({
     method: 'get',
     url: '/api/v1/user',
     headers: {
       'Content-Type': "application/json;charset=UTF-8",
       //把token放到请求头才能请求,这里的'Bearer '表示是后台希望更加的安全,依据后台给的信息看到底是加还是不加
       'Authorization': 'Bearer ' + this.token,
     }
    })
    .then(res=>{          //请求成功后执行函数
    if(res.data.code === 0){
     //请求成功之后给用户名赋值
     this.name=res.data.data.username
     console.log("登录成功")
    }else{
     console.log("登录失败")
    }
   })
   .catch(err=>{          //请求错误后执行函
    console.log("请求错误")
   })
    },
}

这边同理,直接用localstorage取出就好了。

核心代码:

created(){
   //页面加载时就从本地通过localstorage获取存储的token值
    this.token = localStorage.getItem('token')
  },

之后在其他的页面如果还需要把token放到请求头,还是直接通过localstorage的getitem就可以取出了,即localStorage.getItem('token')。

以上这篇vue在响应头response中获取自定义headers操作就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
formvalidator验证插件中有关ajax验证问题
Jan 04 Javascript
用JQuery 判断某个属性是否存在hasAttr的解决方法
Apr 26 Javascript
JavaScript中字符串(string)转json的2种方法
Jun 25 Javascript
window.setInterval()方法的定义和用法及offsetLeft与style.left的区别
Nov 11 Javascript
Javascript之Date对象详解
Jun 07 Javascript
聊一聊Vue.js过渡效果
Sep 07 Javascript
基于JS快速实现导航下拉菜单动画效果附源码下载
Oct 27 Javascript
w3c编程挑战_初级脚本算法实战篇
Jun 23 Javascript
解决LayUI表单获取不到data的问题
Aug 20 Javascript
微信小程序常见页面跳转操作简单示例
May 01 Javascript
JavaScript中工厂函数与构造函数示例详解
May 06 Javascript
JavaScript动画实例之粒子文本的实现方法详解
Jul 28 Javascript
vuex存取值和映射函数使用说明
Jul 24 #Javascript
js实现金山打字通小游戏
Jul 24 #Javascript
vuex中store存储store.commit和store.dispatch的用法
Jul 24 #Javascript
js实现滑动滑块验证登录
Jul 24 #Javascript
解决VUEX的mapState/...mapState等取值问题
Jul 24 #Javascript
对vuex中store和$store的区别说明
Jul 24 #Javascript
小程序实现简单语音聊天的示例代码
Jul 24 #Javascript
You might like
动漫定律:眯眯眼都是怪物!这些角色狠话不多~
2020/03/03 日漫
php中sprintf与printf函数用法区别解析
2014/02/17 PHP
PHP采用curl模仿用户登陆新浪微博发微博的方法
2014/11/07 PHP
基于PHP+jQuery+MySql实现红蓝(顶踩)投票代码
2015/08/25 PHP
Thinkphp5框架简单实现钩子(Hook)行为的方法示例
2019/09/03 PHP
jQuery 学习第五课 Ajax 使用说明
2010/05/17 Javascript
Jquery实现的角色左右选择特效
2014/05/21 Javascript
javascript实现Table间隔色以及选择高亮(和动态切换数据)的方法
2015/05/14 Javascript
JS实现网站菜单拖拽移位效果的方法
2015/09/24 Javascript
js点击文本框弹出可选择的checkbox复选框
2016/02/03 Javascript
Bootstrap媒体对象的实现
2016/05/01 Javascript
javascript实现列表切换效果
2016/05/02 Javascript
基于jQuery实现动态搜索显示功能
2016/05/05 Javascript
jQuery原理系列-常用Dom操作详解
2016/06/07 Javascript
关于js函数解释(包括内嵌,对象等)
2016/11/20 Javascript
jQuery Password Validation密码验证
2016/12/30 Javascript
Javascript DOM事件操作小结(监听鼠标点击、释放,悬停、离开等)
2017/01/20 Javascript
在js中做数字字符串补0(js补零)
2017/03/25 Javascript
利用ECharts.js画K线图的方法示例
2018/01/10 Javascript
vue如何将v-for中的表格导出来
2018/05/07 Javascript
vue 项目中使用Loading组件的示例代码
2018/08/31 Javascript
[01:14]3.19DOTA2发布会 三代刀塔人第二代
2014/03/25 DOTA
Python虚拟环境Virtualenv使用教程
2015/05/18 Python
django自带的server 让外网主机访问方法
2018/05/14 Python
django 使用 request 获取浏览器发送的参数示例代码
2018/06/11 Python
使用python根据端口号关闭进程的方法
2018/11/06 Python
python添加模块搜索路径和包的导入方法
2019/01/19 Python
python实现诗歌游戏(类继承)
2019/02/26 Python
Python要如何实现列表排序的几种方法
2020/02/21 Python
keras 两种训练模型方式详解fit和fit_generator(节省内存)
2020/07/03 Python
使用Python+Appuim 清理微信的方法
2021/01/26 Python
2014年五四青年节活动策划书
2014/04/22 职场文书
2016大一新生军训心得体会
2016/01/11 职场文书
委托开发合同书(标准版)
2019/08/07 职场文书
MySQL选择合适的备份策略和备份工具
2022/06/01 MySQL
ORACLE中dbms_output.put_line输出问题的解决过程
2022/06/28 Oracle