小程序webview嵌入H5页面(H5用vue实现)实现免登录

背景:

最近实现一个功能需要在小程序嵌入其它系统内部的一个页面(用vue写的H5页面),但小程序是无法使用iframe的,所以最终选择小程序官方的webview实现,但是嵌入后一打开这个嵌入的页面就会自动跳转到H5的登录页,原因是被嵌入系统没有登录(没有token)肯定不让访问内部页面的,本文就是解决这个问题的。

选择的技术方案:

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

本地小程序系统
<web-view src="{{webUrl}}"/>

// webUrl: `https://×××××××××?token=${token}`

使用webview标签,webUrl是嵌入系统对应页面的url,可以通过url?后面传参数把参数带到对应的H5系统

被嵌入的H5系统(H5用vue实现)
created() {
    // H5获取token
    const wxobj = {}
    window.location.href.replace(/([^?&=]+)=([^&]+)/g, (_, k, v) => (wxobj[k] = v))
    if ( wxobj.token) {
      store.commit( 'user/setToken', wxobj.token)
    }
}

被嵌入页面在App.vue文件created生命周期获取到token放到缓存中就能做到免登录了

注意:

  • 最好把token加密一下,要不然直接显示在url是非常危险的行为
  • 上面接收方要在在APP.vue文件的created生命周期接收,在嵌入页面接收是不行的,这里与VUE的执行流程有关就不多说了
Uniapp是一款基于Vue.js框架的跨平台开发工具,支持在一套代码中开发出运行于各大平台的应用程序。当我们需要在Uniapp应用程序中嵌入h5页面时,可以通过使用uniWebView组件来实现。uniWebView是Uniapp官方提供的一个支持在小程序、APP中加载H5页面、原生组件的组件。下面简单介绍一下uniWebView组件的使用。 首先,在需要使用webview页面中导入uniWebView组件: ``` <template> <view class="uni-page"> <uni-web-view :src="url"></uni-web-view> </view> </template> <script> import uniWebView from '@/components/uni-web-view/uni-web-view.vue'; export default { components: { uniWebView }, data() { return { url: 'https://www.baidu.com' // 设置要加载的H5地址 } } } </script> ``` 在页面中添加uni-web-view标签,并通过src属性指定需要加载的H5页面的地址。当然,我们还可以通过设置其他属性来控制webview的行为,比如设置webview的高度、宽度、背景颜色、是否启用缩放等。 需要注意的是,在使用uniWebView组件时,需要在manifest.json中配置webview权限,否则会导致无法加载H5页面。在manifest.json文件中,我们需要添加以下代码: ``` "app-plus": { "useWebview": true, // 允许使用webview组件 "webview": { "popGesture": "close", "subNViews": true, // 开启uni-subNVue "bounce": "none", "plusrequire": "none", "uniNView": { "defaultFontSize": 16 }, "permission": { "webview": { "default": { "state": 1, // 允许加载H5页面 "des": "WebView 权限" } } }, } } ``` 通过以上配置,我们就可以在Uniapp应用程序中顺利地嵌入H5页面,并且能够自由地控制webview的行为。但需要注意的是,由于uniWebView组件比较占用资源,因此还需要充分优化应用程序性能,避出现卡顿等问题。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值