最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

基于vue 实现token验证的实例代码

来源:动视网 责编:小采 时间:2020-11-27 22:23:37
文档

基于vue 实现token验证的实例代码

基于vue 实现token验证的实例代码:vue-koa2-token 基于vue的 做了token验证 前端部分(对axios设置Authorization) import axios from 'axios' import store from '../store' import router from '../router' //设置全局axios默认值 axios.defa
推荐度:
导读基于vue 实现token验证的实例代码:vue-koa2-token 基于vue的 做了token验证 前端部分(对axios设置Authorization) import axios from 'axios' import store from '../store' import router from '../router' //设置全局axios默认值 axios.defa


vue-koa2-token

基于vue的 做了token验证

前端部分(对axios设置Authorization)

import axios from 'axios'
import store from '../store'
import router from '../router'
//设置全局axios默认值
axios.defaults.timeout = 6000; //6000的超时验证
axios.defaults.headers.post['Content-Type'] = 'application/json;charset=UTF-8';
//创建一个axios实例
const instance = axios.create();
instance.defaults.headers.post['Content-Type'] = 'application/json;charset=UTF-8';
axios.interceptors.request.use = instance.interceptors.request.use;
//request
instance.interceptors.request.use(
 config => {
 //每次发送请求之前检测都vuex存有token,那么都要放在请求头发送给服务器
 if(store.state.token){
 config.headers.Authorization = `token ${store.state.token}`;
 }
 return config;
 },
 err => {
 return Promise.reject(err);
 }
);
//respone
instance.interceptors.response.use(
 response => {
 return response;
 },
 error => { //默认除了2XX之外的都是错误的,就会走这里
 if(error.response){
 switch(error.response.status){
 case 401:
 store.dispatch('UserLogout'); //可能是token过期,清除它
 router.replace({ //跳转到登录页面
 path: 'login',
 query: { redirect: router.currentRoute.fullPath } // 将跳转的路由path作为参数,登录成功后跳转到该路由
 });
 }
 }
 return Promise.reject(error.response);
 }
);
export default instance;

 然后在路由文件中

 //注册全局钩子用来拦截导航
router.beforeEach((to, from, next) => {
 //获取store里面的token
 let token = store.state.token;
 //判断要去的路由有没有requiresAuth
 if(to.meta.requiresAuth){
 if(token){
 next();
 }else{
 next({
 path: '/login',
 query: { redirect: to.fullPath } // 将刚刚要去的路由path(却无权限)作为参数,方便登录成功后直接跳转到该路由
 });
 }
 }else{
 next();//如果无需token,那么随它去吧
 }
});

后端(node) 我们封装了一个中间件 在需要验证token的路由,加上这个中间件

 router.get('/dosh',checkToken,User.dosh)
const jwt = require('jsonwebtoken');

1、使用jsonwebtoken 创建token

const jwt = require('jsonwebtoken');
//登录时:核对用户名和密码成功后,应用将用户的id(图中的user_id)作为JWT Payload的一个属性
module.exports = function(user_id){
 const token = jwt.sign({
 user_id: user_id
 }, 'sinner77', {
 expiresIn: '3600s' //过期时间设置为60妙。那么decode这个token的时候得到的过期时间为 : 创建token的时间 + 设置的值
 });
 return token;
};

2、对于前端的请求,校验接口

//检查token是否过期
module.exports = async ( ctx, next ) => {
 if(ctx.request.header['authorization']){
 let token = ctx.request.header['authorization'].split(' ')[1];
 //解码token
 let decoded = jwt.decode(token, 'sinner77');
 //console.log(decoded);的
输出 :{ user_id: '123123123', iat: 1494405235, exp: 1494405235 } if(token && decoded.exp <= new Date()/1000){ ctx.status = 401; ctx.body = { message: 'token过期' }; }else{ //如果权限没问题,那么交个下一个控制器处理 return next(); } }else{ ctx.status = 401; ctx.body = { message: '没有token' } } };

代码托管github 欢迎star

https://github.com/yxl720/vue-koa2-token

总结

以上所述是小编给大家介绍的基于vue 实现token验证的实例代码,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持!

文档

基于vue 实现token验证的实例代码

基于vue 实现token验证的实例代码:vue-koa2-token 基于vue的 做了token验证 前端部分(对axios设置Authorization) import axios from 'axios' import store from '../store' import router from '../router' //设置全局axios默认值 axios.defa
推荐度:
标签: 验证 VUE 实现
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top