当前位置: 首页 > news >正文

iframe嵌入Vue页面实现免登方法

简介:实现一个功能需要使用iframe嵌入其它系统内部的一个页面,但嵌入后出现一个问题,就是一打开这个页面就会自动跳转到登录页,原因是被嵌入系统没有登录(没有token)肯定不让访问内部页面的,本文就是解决这个问题的。

解决技术方案:本地系统使用iframe嵌入某个系统内部页面,那就证明被嵌入系统是安全的可使用的,所以可以通过通讯方式带一个token过去实现免登录,我用vue项目作为例子具体如下:

方法一通过url传: 

// 发送方(本地系统):
<div><iframe :src="url" id="childFrame" importance="high" name="demo" ></iframe>
</div>//被嵌入页面进行接收
url = `http://localhost:8080/dudu?mytoken={mytoken}` //  接收方:直接使用window.location.search接收,然后对接收到的进行处理

注意:

  • 如果使用这个方法最好把token加密一下,要不然直接显示在url非常危险的行为,所以我更推荐下面方法二
  • 上面接收方要在在APP.vue文件的created生命周期接收,在嵌入页面接收是不行的,这里与Vue的执行流程有关就不多说了

方法二通过iframe的通讯方式传(值的推荐): 

// 发送方(本地系统):var params = {type: "setToken",token: "这是传过去的token"
}
window.parent.postMessage(params, "*");// 接收方(被嵌入系统):在APP.vue文件的created生命周期接收
window.addEventListener( "message",(e)=>{if(e.data.type === 'setToken'){//这里拿到token,然后放入缓存实在免登录即可}}	
false);

 注意注意: 上面接收方要在在APP.vue文件的created生命周期接收,在嵌入页面接收是不行的,这里与Vue的执行流程有关就不多说了。

http://www.lryc.cn/news/336976.html

相关文章:

  • 详解TCP/IP五层模型
  • 开创加密资产新纪元:深度解析ERC-314协议
  • Rust 实战练习 - 9. 文本编码,URL编码,加密解密
  • linux环境openfile限制
  • python之pandas数据导入和导出
  • Docker 集成 redis,并在nacos进行配置时需要注意点
  • 数据库系统工程师考试大纲
  • (Java)数据结构——图(第七节)Folyd实现多源最短路径
  • 使用Python进行高效的多线程HTTP请求
  • 如何利用OceanBase v4.2的 外部表简化外部数据处理
  • 【灵境矩阵】零代码创建AI智能体之行业词句助手
  • springboot 防抖操作
  • Playwright录制脚本 —— web自动化测试!
  • 什么是工业级物联网智能网关?如何远程控制PLC?
  • AI推介-大语言模型LLMs论文速览(arXiv方向):2024.04.05-2024.04.10
  • javascript:call()、apply()、bind()的区别和使用
  • ubuntu系统安装systemc-2.3.4流程
  • Java开发中的entity、vo和pojo
  • 通过IPV6+DDNS实现路由器远程管理和Win远程桌面控制
  • 数据湖/数据仓库
  • 万兆以太网MAC设计(2)MAC_RX模块
  • D. Solve The Maze Codeforces Round 648 (Div. 2)
  • CPU核心数、线程数都是什么意思?
  • 每日一篇 4.12
  • 鸿蒙南向开发:【智能烟感】
  • 【主题广|检索稳定】2024年生态工程与农业科技国际会议 (EEAT 2024)
  • 代码随想录算法训练营第三十八天|509. 斐波那契数、 70. 爬楼梯、746. 使用最小花费爬楼梯
  • 07-app端文章搜索
  • ✔ ★Java项目——设计一个消息队列(二)
  • Java语言实现生产者/消费者问题