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的执行流程有关就不多说了。

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-04-13 01:40:04       94 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-04-13 01:40:04       100 阅读
  3. 在Django里面运行非项目文件

    2024-04-13 01:40:04       82 阅读
  4. Python语言-面向对象

    2024-04-13 01:40:04       91 阅读

热门阅读

  1. 什么是感知器 怎么学习感知器

    2024-04-13 01:40:04       35 阅读
  2. 2、ipex-llm(原bigdl-llm)应用聊天

    2024-04-13 01:40:04       39 阅读
  3. P2678 [NOIP2015 提高组] 跳石头

    2024-04-13 01:40:04       38 阅读
  4. Golang 为什么需要用反射

    2024-04-13 01:40:04       36 阅读
  5. Leetcode56_合并区间

    2024-04-13 01:40:04       39 阅读
  6. Latex中todonotes超出页面范围及其他参数说明

    2024-04-13 01:40:04       39 阅读
  7. 第十三届蓝桥杯省赛C&C++ 研究生组2.0

    2024-04-13 01:40:04       38 阅读
  8. Ajax跨域请求

    2024-04-13 01:40:04       36 阅读