Vue不同项目之间传递、接收参数问题

作者:To 时间:2024-04-30 10:47:06 

描述一下场景

UC(User-Center)是单独的一个项目,包括Spring Cloud + Vue, 服务项目是另一个项目,也是Spring Cloud+ Vue

这里主要针对是登录操作,我们为了完成SSO(Single Sign On)的效果,认证和授权在UC完成,用户发起资源请求,服务网关会进行过滤,判断请求头中是否有token以及token是否过期,不满足就会带着原访问资源项目的主页(这里记为uri)重定向到登录页面,此时就是登录的相关操作,进行完以后会生成一个token标识,这时候要根据带来的uri进行页面跳转,此时要带上token标识过去。

关于token的携带,以下是几种方式的分析: 

1.LocalStroage方式 (不可取)

如果可以用localStorage来存储token,这样就不用来回带着token信息,直接在服务项目的vue请求 * 中把token放到headers里边就可以了? 事实是不可取的,因为localStorage 只在有相同的协议、相同的主机名、相同的端口下,才能读取/修改到同一份localStorage数据。 这里我们是两个vue项目,所以无法共享token,其次,假如这种方式可以,难道我们访问百度还能用访问腾讯时候存的localStorage里边的标识?所以,PASS.

localStorage深入了解:localstorage 必知必会 

2.Cookie方式 (不推荐)

使用Cookie进行共享,也就是说在UC的vue项目中,登录成功,将token存入cookie中,在服务项目的vue请求 * 中获取cookie先存入localStorage中,然后放入headers,这样之后每次从localStorage中拿出token放入headers即可。实现上是可以的因为cookie在两个vue项目之间是共享的。但是,不好的点是,其一是如果cookie被禁用了怎么办?,尽管可以处理但是还是说明这个方法存在一些明显的不足,其次存cookie是很老套的方式,市面上也很少用到。关于多个cookie参数,如果获取某一个cookie值的方法封装:

window.getCookie = function(name) {
      var match = document.cookie.match(new RegExp('(^| )' + name + '=([^;]+)'));
      if (match) return match[2];
}

 存:

document.cookie = "token=1234";

取:

let token = getCookie('token');

3.参数形式 (时效性)

直接以参数形式传递,在另一方获取请求参数,再放入localStorage中。看起来这种方式似乎是最直接的,其实来说它也保证了token的时效性,但是写的时候可真给我恶心坏了,不说了只能怪咱百度不会用,其实以参数传递的方式还有很多种,可以多使用几种,这里暂且总结一种,后序填坑。

传: 拼到url中

Vue不同项目之间传递、接收参数问题

 取:一定是在页面获取,无法在请求 * 取出

Vue不同项目之间传递、接收参数问题

来源:https://blog.csdn.net/weixin_47255175/article/details/124027993

标签:vue,项目,传参
0
投稿

猜你喜欢

  • python切片操作方法的实例总结

    2021-02-28 12:51:01
  • 让表单 input 只能输入数字

    2008-06-08 13:54:00
  • Python连接Hadoop数据中遇到的各种坑(汇总)

    2023-09-13 20:16:34
  • Django实现快速分页的方法实例

    2022-12-27 06:02:30
  • python爬取酷狗音乐排行榜

    2021-01-24 19:43:49
  • python3爬虫中异步协程的用法

    2021-11-01 01:16:02
  • Python基于lxml模块解析html获取页面内所有叶子节点xpath路径功能示例

    2022-11-13 00:12:24
  • javascript实现json页面分页实例代码

    2024-02-25 09:38:56
  • Go 语言中 20 个占位符的整理

    2024-04-23 09:45:21
  • MYSQL数据库实用学习资料之常用命令集合

    2009-03-06 18:12:00
  • 基于Python Numpy的数组array和矩阵matrix详解

    2022-04-22 10:52:28
  • Pycharm远程连接服务器跑代码的实现

    2021-06-19 21:13:54
  • python之OpenCV的作用以及安装案例教程

    2021-11-27 07:14:20
  • 使用cmd命令行窗口操作SqlServer的方法

    2012-07-21 14:24:06
  • Vuex模块化实现待办事项的状态管理

    2024-04-27 15:59:55
  • 如何用我的国际域名做虚拟域名?

    2010-06-16 09:53:00
  • C++中的string类的用法小结

    2024-04-10 16:09:24
  • Python中optparse模块使用浅析

    2023-10-21 06:55:38
  • Python运用于数据分析的简单教程

    2023-08-14 07:49:13
  • Vue.js性能优化N个技巧(值得收藏)

    2024-04-16 10:40:51
  • asp之家 网络编程 m.aspxhome.com