当前位置: 首页 > 知识库问答 >
问题:

java-web - 关于前端跳转如何携带Token?

濮阳赞
2024-03-24

新手提问:
第一次用JavaWeb做一个小项目,但是在用户登录模块这边遇到了一个问题:
由于我是做的类似于管理之类的前端项目,登录页面和主页面都是两个页面。在登录页面第一次登录成功后,后端会返回Token值给前端,前端如何做到跳转到主页面的时候也在请求头里加入Token值呢?因为在后端我是用了每一个请求都检查请求头的Token值的方法

目前Cookies、url拼接已经试过,都可以,想试试其他方法..

共有2个答案

丘华翰
2024-03-24

前端一般都会使用一个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

寿毅庵
2024-03-24

你说的意思是如何在登录成功以后每次调用后端请求都带上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.算法题:冒泡排序