新手提问:
第一次用JavaWeb做一个小项目,但是在用户登录模块这边遇到了一个问题:
由于我是做的类似于管理之类的前端项目,登录页面和主页面都是两个页面。在登录页面第一次登录成功后,后端会返回Token值给前端,前端如何做到跳转到主页面的时候也在请求头里加入Token值呢?因为在后端我是用了每一个请求都检查请求头的Token值的方法
目前Cookies、url拼接已经试过,都可以,想试试其他方法..
前端一般都会使用一个http
库,比如说 axios。
就可以在请求拦截其中手动添加一些参数,比如说你需求的 token
。
以下是一个请求拦截器的样例,你可以参考一下:
import axios from 'axios'// 创建axios实例const service = axios.create({ // axios中请求配置有baseURL选项,表示请求URL公共部分 baseURL: process.env.VUE_APP_BASE_API, // 超时 timeout: 10000})// request拦截器service.interceptors.request.use(config => { // 是否需要设置 token const isToken = (config.headers || {}).isToken === false // 是否需要防止数据重复提交 const isRepeatSubmit = (config.headers || {}).repeatSubmit === false if (getToken() && !isToken) { config.headers['Authorization'] = 'Bearer ' + getToken() // 让每个请求携带自定义token 请根据实际情况自行修改 } // get请求映射params参数 if (config.method === 'get' && config.params) { let url = config.url + '?' + tansParams(config.params); url = url.slice(0, -1); config.params = {}; config.url = url; } if (!isRepeatSubmit && (config.method === 'post' || config.method === 'put')) { const requestObj = { url: config.url, data: typeof config.data === 'object' ? JSON.stringify(config.data) : config.data, time: new Date().getTime() } const requestSize = Object.keys(JSON.stringify(requestObj)).length; // 请求数据大小 const limitSize = 5 * 1024 * 1024; // 限制存放数据5M if (requestSize >= limitSize) { console.warn(`[${config.url}]: ` + '请求数据大小超出允许的5M限制,无法进行防重复提交验证。') return config; } const sessionObj = cache.session.getJSON('sessionObj') if (sessionObj === undefined || sessionObj === null || sessionObj === '') { cache.session.setJSON('sessionObj', requestObj) } else { const s_url = sessionObj.url; // 请求地址 const s_data = sessionObj.data; // 请求数据 const s_time = sessionObj.time; // 请求时间 const interval = 1000; // 间隔时间(ms),小于此时间视为重复提交 if (s_data === requestObj.data && requestObj.time - s_time < interval && s_url === requestObj.url) { const message = '数据正在处理,请勿重复提交'; console.warn(`[${s_url}]: ` + message) return Promise.reject(new Error(message)) } else { cache.session.setJSON('sessionObj', requestObj) } } } return config}, error => { console.log(error) Promise.reject(error)})
也可以直接看这个仓库中关于拦截器部分的配置 ruoyi-ui/src/utils/request.js
你说的意思是如何在登录成功以后每次调用后端请求都带上token是吗?如果是这样的话,你可以思考一下,你的后端在处理请求时,是怎么处理token的,我想你应该是有一个拦截器,在所有请求处理前进行操作,而不是每个方法都做token的处理。所以在前端也会有一个拦截器的方法。axios有一个方法httpService.interceptors.request.use可以帮你解决这个问题。
笔试 3.29 携程一面 4.7 自我介绍 vue-router原理 页面如何跳转 刷新之后页面会回退吗?不会,但是不知道为什么 vuex原理 如何全局状态管理?如果和页面中的变量冲突该怎么办?没遇到过不知道为什么 跨域 原理 解决办法 浏览器可以做什么来解决跨域吗?我回答浏览器不用做 模块化语法 import 属于什么规范?其他规范有了解吗 写题 判断是否回文 推荐用正则 正则匹配的replac
问题: 前端如何跳转页面路径 ? 我尝试使用了路由的语法, 但是没有跳转
vue组件demo,内嵌了iframe,src='www.xxx.com/aaa' 现在aaa页面内部路由跳转之后,如何在组件demo中获取到最新的跳转链接 通过监听iframe的onload事件,拿到的src始终都是www.xxx.com/aaa
今天(7月3号)面试了一家游戏主播 公司属于公会,提供流量,有线下直播间提供,熟手后可线上居家 YY公会:火焰 公司名称:深圳市剑盾文化传媒 薪资待遇:底薪3000签5年主播协议(不属于劳务或劳动协议),直播收入3000以上我7公司3,直播收入3000以下,公司补够3000 暂居地点到公司坐地铁+步行2小时,进去一个小伙倒一杯水,然后扔我一张表填个人信息,有身份证、抖音、快手、YY账号、现居地等等
1.概况 10.19收到了携程约面的通知于是就约到了今天下午的3:20,面试时长48min,面试官很友好,二面是部门交叉面,面试体验还行。 2.面经 面试官自我介绍(面试官特别的友好) 自我介绍 水平垂直居中的方式(常经典八股) cookie和localstoraged的区别 怎样保证cookie的安全 技术栈 兄弟组件通信的方式 暑期实习(单元测试回答不好) 最近的一些项目(SEO优化问题表述不
1.自我介绍 2.项目中应用到的技术 3.对前端新框架的关注度(从哪里关注之类的闲聊、vite、自我学习规划) 4.vue生命周期 5.监听首页白屏 6.webpack打包优化手段 7.箭头函数与普通函数的区别 8.算法题:反转链表 9.undefined和null区别 10.浏览器输入url到显示网页之间发生了什么 11.内存泄露 12.let var const 区别 13.算法题:冒泡排序