菜单

网页程序迁移至微信小程序web-view详解

2018年11月16日 - JavaScript

网页程序迁移到微信小程序web-view详解

2018/08/02 · JavaScript
· 小程序

初稿出处: NeoPasser   

稍加序现在更进一步流行,但是公司的过剩型都是为此网页写的,小程序语法不匹配原生网页,使得原本有品种搬迁到略程序代价十分高。

稍序之前开放了webview功能,可以说凡是网页应用之同一非常福音了,但是微信的webview有一些坑,这首文章就是是列举一下自家以支付进程中遇的有问题与自身找到的局部解决方案。

微信小程序 解析网页内容详解

碰到的问题

  1. openid登录问题
  2. webview动态src
  3. 支付功能
  4. 享受功能
  5. 环顾普通二维码跳转特定页面
  6. 返回按钮缺失问题

不久前以形容一个爬虫,需要以网页进行分析供微信小序用。文字与图纸解析都吓说,小序也来相应的text和image标签可以表现。而更扑朔迷离的,比如表格,则较费劲,不管是服务端解析还是有些程序呈现都怪棘手,也生为难掩所有情况。于是自己怀念,将表格对应之HTML代码转成为图,不失为一栽转移之章程。

openid登录问题

微信webview的运方式好粗略,只要如下设置src就可显示具体的网站了。

<!– wxml –> <!– 指向微信公众平台首页的web-view –>
<web-view src=”https://mp.weixin.qq.com/"&gt;&lt;/web-view&gt;

1
2
3
<!– wxml –>
<!– 指向微信公众平台首页的web-view –>
<web-view src="https://mp.weixin.qq.com/"></web-view>

微信环境里之很多网页都是用页面要兑现网站的记名功能,只要拿登录的消息,比如openid或者其它信息集成接到src里虽吓了。

这里产生个问题,公众号的账号体系一般是坐openid来判定唯一性的,小序是可以抱openid的,但是小序的openid和原先公众号之类的openid是休均等的,需要将原来的openid账号体系提升也unionid账号体系。

以下是微信对unionid的介绍

博用户基本信息(UnionID机制)

于关注者与民众号有信息交互后,公众号只是得关注者的OpenID(加密后底微信号,每个用户对每个公众号的OpenID是绝无仅有的。对于不同公众号,同一用户的openid不同)。公众号只是透过本接口来因OpenID获取用户核心信息,包括昵称、头如、性别、所在城市、语言和关怀时间。

伸手留意,如果开发者有以多单公众号,或在公众号、移动采用内联合用户帐号的急需,需要前往微信开放平台(open.weixin.qq.com)绑定公众号晚,才可使用UnionID机制来满足上述要求。

UnionID机制说明:

开发者可透过OpenID来赢得用户基本信息。特别需要专注的是,如果开发者拥有多单移动应用、网站采取与大众帐号,可经取得用户中心信息中的unionid来分用户之唯一性,因为若是和一个微信开放平台帐号下之走使用、网站使用与大众帐号,用户的unionid是唯一的。换句话说,同一用户,对同一个微信开放平台下的差应用,unionid是均等之。

做得了以上步骤,就好调用小程序api wx.getUserInfo()
来抱用户信息了,此步骤需要进行后台信息解密过程,在这便不再赘述,结合小程序api文档操作就好。

博到unioid之后,将unionid信息集成接到src就足以进行网页登录操作了(前提是网页可以据此越反链接的法登录,类似群众号页面获得openid的款型)。

此我们采取node-webshot模块,它对PhantomJS进行了轻量封装,可以轻松地将网页为截图形式保留下去。

webview动态src

微信的webview有只坑的地方,不会见动态的监听src的变迁,这就算导致了一个题目,要由此改动src实现页面跳反不怕无得以了。
自我尝试了一部分法后,找到了一个缓解方案:

微信webview于页面load的时光会加载一破webview,我们即便使这个特性来贯彻动态src问题。

  1. 首先把要跳转的链接信息设置成全局变量,要改src的时刻,先管要src以’?‘拆分为链接和参数两部分,存入全局函数,再调用onLoad就可以兑现webview刷新了。
  2. 页面跳反时,我们为需要src的动态刷新,所以一旦管链接信息存入全局函数;页面跳反时,onShow函数会受调用,这时候再调用一软onLoad就好了。

data: { url: ”, loaded: false } // 小程序js里之onLoad函数可以形容成这样
onLoad: function () { this.setData({ url: getApp().globalData.urlToken +
‘?’ + getApp().globalData.urlData }) }, changUrl: function () {
getApp().globalData.urlToken = ‘https://www.example.com’
getApp().globalData.urlToken = ‘a=1&b=2’ //
直接调用onLoad,就见面实现src的基础代谢 this.onLoad() }, onShow: function () {
if (!this.data.loaded) { // 第一次于无运行 this.setData({ loaded: true })
return } // 直接调用onLoad,就见面落实src的刷新 this.onLoad() } //
wxml可以写成这样 <web-view src=”{{url}}”></web-view>

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
data: {
    url: ”,
    loaded: false
}
// 小程序js里的onLoad函数可以写成这样
onLoad: function () {
    this.setData({
      url: getApp().globalData.urlToken + ‘?’ +  getApp().globalData.urlData
    })
},
changUrl: function () {
    getApp().globalData.urlToken = ‘https://www.example.com’
    getApp().globalData.urlToken = ‘a=1&b=2’
    // 直接调用onLoad,就会实现src的刷新
    this.onLoad()
},
onShow: function () {
    if (!this.data.loaded) {
      // 第一次不运行
      this.setData({
        loaded: true
      })
      return
    }
    // 直接调用onLoad,就会实现src的刷新
    this.onLoad()
  }
 
// wxml可以写成这样
<web-view src="{{url}}"></web-view>

第一安装Node.js和PhantomJS,然后新建一个js文件,加载node-webshot模块:

支付功能

webview里面可以透过jssdk来促成有粗序功能,但不克直接调用小程序的开销功能,这时候我们便用扭转一下策了:

  1. 以网页里引入微信jssdk
  2. 于网页需要倡导支付的地方,调用跳转页面的接口,控制小程序跳反至有些序的出页面(这个要当小序里单独写的),跳转的时刻,需要将订单的局部信都凑合到链接里,订单信息由后台返回,需要经过微信支付体系的联合下单接口,具体参看支付文档。
  3. 跨反至小序开发页面后,由小程序页面发起支付,支付成功后超过反回webview页面,通过前安装的动态src,控制webview跳转至特定的页面。

JavaScript

// 网页引入jssdk // 网页发起支付 wx.miniProgram.navigateTo({ //
payData由后台返回,主要是待统一下仅仅平台的prepay_id url:
‘../pay/index?data=’ + encodeURIComponent(JSON.stringify(payData)) }) //
微信支付页面 onLoad: function (option) { let page = this try { let data
= JSON.parse(option.data) if (!data || !data.prepay_id) {
console.error(‘支付参数错误,请稍晚再度试’, data) } wx.requestPayment({
timeStamp: ” + data.timestamp, nonceStr: data.nonceStr, package:
‘prepay_id=’ + data.prepay_id, paySign: data.paySign, signType:
data.signType, success: function (res) { getApp().globalData.urlToken =
`paySuccess.html` // 支付成功 getApp().globalData.urlData =
‘data=paySuccessData’ wx.navigateTo({ url: ‘/page/home/index’, }) },
fail: function (res) { getApp().globalData.urlToken = `payError.html`
// 支付失败 getApp().globalData.urlData = ‘data=payErrorData’
wx.navigateTo({ url: ‘/page/home/index’, }) }, complete: function (res)
{ } }) } catch (e) { console.error(‘支付错误’, e) } }

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
// 网页引入jssdk
 
// 网页发起支付
wx.miniProgram.navigateTo({
    // payData由后台返回,主要是需要统一下单平台的prepay_id
    url: ‘../pay/index?data=’ + encodeURIComponent(JSON.stringify(payData))
})
// 微信支付页面
onLoad: function (option) {
    let page = this
    try {
      let data = JSON.parse(option.data)
      if (!data || !data.prepay_id) {
        console.error(‘支付参数错误,请稍后重试’, data)
      }
      wx.requestPayment({
        timeStamp: ” + data.timestamp,
        nonceStr: data.nonceStr,
        package: ‘prepay_id=’ + data.prepay_id,
        paySign: data.paySign,
        signType: data.signType,
        success: function (res) {
          getApp().globalData.urlToken = `paySuccess.html`
          // 支付成功
          getApp().globalData.urlData = ‘data=paySuccessData’
          wx.navigateTo({
            url: ‘/page/home/index’,
          })
        },
        fail: function (res) {
          getApp().globalData.urlToken = `payError.html`
          // 支付失败
          getApp().globalData.urlData = ‘data=payErrorData’
          wx.navigateTo({
            url: ‘/page/home/index’,
          })
        },
        complete: function (res) {
        }
      })
    } catch (e) {
      console.error(‘支付错误’, e)
    }
  }
const webshot = require('webshot');

分享功能

稍序直接分享的webview所在的页面,如果欲添加页面参数,那咱们就算得处理一下了。

  1. webview内是休克直接发起分享的,需要先用wx.miniProgram.postMessage接口,把需要分享的信,推送给多少程序;推送给小序的音不是实时处理的,而是用户点击了分享按钮后,小序才回到读取的,这即要求每个需要分享的页面还进入的时就发起wx.miniProgram.postMessage推送分享信息为多少程序。
  2. 稍许程序页面通过bindmessage绑定的函数读取post信息,分享的信会是一个列表,我们收获最后一个享就哼,把分享信息处理好,存到data里面以便下一致步onShareAppMessage调用。
  3. 用户点击分享时,会触发onShareAppMessage函数,在中间装好相应之分享信息就是哼了。
  4. onload函数有一个option参数的,可以读取页面加载时url里带的参数,这时如针对性本来的onload函数进行改造,实现从option里读取链接信息。

JavaScript

// 网页wx.miniProgram.postMessage wx.miniProgram.postMessage({ data: {
link: shareInfo.link, title: shareInfo.title, imgUrl: shareInfo.imgUrl,
desc: shareInfo.desc } }) // 小程序index wxml设置 <web-view
src=”{{url}}” bindmessage=”bindGetMsg”></web-view> //
小程序index js bindGetMsg: function (e) { if (!e.detail) { return } let
list = e.detail.data if (!list || list.length === 0) { return } let info
= list[list.length – 1] if (!info.link) {
console.error(‘分享信息错’, list) return } let tokens =
info.link.split(‘?’) this.setData({ shareInfo: { title: info.title,
imageUrl: info.imgUrl, path:
`/page/index/index?urlData=${encodeURIComponent(tokens[1])}&urlToken=${tokens[0]}`
} }) }, onShareAppMessage: function (res) { if (res.from === ‘button’) {
// 来自页面内转发本钮 console.log(res.target) } let that = this return {
title: that.data.shareInfo.title, path: that.data.shareInfo.path,
imageUrl: that.data.shareInfo.imageUrl, success: function (res) { //
转发成 }, fail: function (res) { // 转发失败 } } }, onLoad: function
(option) { if (option.urlToken) { getApp().globalData.urlToken =
option.urlToken } if (option.urlData) { getApp().globalData.urlData =
option.urlData } this.setData({ url: getApp().globalData.urlToken + ‘?’

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
// 网页wx.miniProgram.postMessage
wx.miniProgram.postMessage({
  data: {
    link: shareInfo.link,
    title: shareInfo.title,
    imgUrl: shareInfo.imgUrl,
    desc: shareInfo.desc
  }
})
// 小程序index wxml设置
<web-view src="{{url}}" bindmessage="bindGetMsg"></web-view>
// 小程序index js
bindGetMsg: function (e) {
    if (!e.detail) {
      return
    }
    let list = e.detail.data
    if (!list || list.length === 0) {
      return
    }
    let info = list[list.length – 1]
    if (!info.link) {
      console.error(‘分享信息错误’, list)
      return
    }
    let tokens = info.link.split(‘?’)
    this.setData({
      shareInfo: {
        title: info.title,
        imageUrl: info.imgUrl,
        path: `/page/index/index?urlData=${encodeURIComponent(tokens[1])}&urlToken=${tokens[0]}`
      }
    })
},
onShareAppMessage: function (res) {
    if (res.from === ‘button’) {
      // 来自页面内转发按钮
      console.log(res.target)
    }
    let that = this
    return {
      title: that.data.shareInfo.title,
      path: that.data.shareInfo.path,
      imageUrl: that.data.shareInfo.imageUrl,
      success: function (res) {
        // 转发成功
      },
      fail: function (res) {
        // 转发失败
      }
    }
},
onLoad: function (option) {
    if (option.urlToken) {
      getApp().globalData.urlToken = option.urlToken
    }
    if (option.urlData) {
      getApp().globalData.urlData = option.urlData
    }
    this.setData({
      url: getApp().globalData.urlToken + ‘?’ +  getApp().globalData.urlData
    })
},

概念选项:

环顾普通二维码跳转特定页面

除了享受功能之外,小序还可通过部署,实现扫描普通二维码跳转特定页面的效果。

以下是微信对斯作用的牵线

为了便利小程序开发者重新轻便地放开小序,兼容线下已有些二维码,微信公众平台开放扫描普通链接二维码跳反小序能力。

作用介绍

便链接二维码,是凭借开发者使用工具对网页链接进行编码后生成的老二维码。

丝下商户可免欲更换线下二维码,在多少序后台完成布局后,即可在用户扫描普通链接二维码时打开小程序,使用小程序的效应。
对于一般链接二维码,目前支持下微信“扫一扫”或微信内长按识别二维码跳转小程序.

二维码规则

基于二维码跳转规则,开发者需要填需要过反小序的次维码规则。要求如下:

  1. 二维码规则之域名须经过ICP备案的证明。
  2. 支撑http、https、ftp开头的链接(如:http://wx.qq.com、https://wx.qq.com/mp/、https://wx.qq.com/mp?id=123)。
  3. 一个小序帐号只是部署不多给10单二维码前缀规则。

前缀占用规则

开发者可摘是否占用符合二维码匹配规则之所有子规则。如选择占用,则其它帐号不可申请采用满足该前缀匹配规则的其余子规则。

苟:若开发者A配置二维码规则:https://wx.qq.com/mp?id=123,并选“占用所有子规则“,其他开发者将不可以配备满足前缀匹配的杜鹃则要https://wx.qq.com/mp?id=1234。

自身推荐的主意

webview实现方式

  1. 安装跳转功能小序后台就得设置,链接是分为四片段,路https://www.example.com/wxmin…。

    https://www.example.com 域名
    /wxmini/ 小程序前置规则,需要在服务器上建一个文件夹,并且把验证文件放在文件夹线
    home.html 需要跳转的网页页面
    a=1 跳转页面的参数
  2. 本着onload函数再进行拍卖,实现日常二维码跳转。

JavaScript

// 对index onLoad在展开处理 onLoad: function (option) {
this.resetOption(option) if (option.urlToken) {
getApp().globalData.urlToken = option.urlToken } if (option.urlData) {
getApp().globalData.urlData = option.urlData } this.setData({ url:
getApp().globalData.urlToken + ‘?’ + getApp().globalData.urlData }) },
resetOption: function (option) { if (!option) { return } if (option.q) {
option.q = decodeURIComponent(option.q) if
(option.q.indexOf(‘https://www.example.com/wxmini/’) == -1) { return }
let tmp = option.q.replace(‘/wxmini’, ”) let tmps = tmp.split(‘?’)
option.urlToken = tmps[0] option.urlData = tmps[1] } else {
option.urlData = decodeURIComponent(option.urlData) } }

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
// 对index onLoad在进行处理
onLoad: function (option) {
    this.resetOption(option)
    if (option.urlToken) {
      getApp().globalData.urlToken = option.urlToken
    }
    if (option.urlData) {
      getApp().globalData.urlData = option.urlData
    }
    this.setData({
      url: getApp().globalData.urlToken + ‘?’ +  getApp().globalData.urlData
    })
},
resetOption: function (option) {
    if (!option) {
      return
    }
    if (option.q) {
      option.q = decodeURIComponent(option.q)
      if (option.q.indexOf(‘https://www.example.com/wxmini/’) == -1) {
        return
      }
      let tmp = option.q.replace(‘/wxmini’, ”)
      let tmps = tmp.split(‘?’)
      option.urlToken = tmps[0]
      option.urlData = tmps[1]
    } else {
      option.urlData = decodeURIComponent(option.urlData)
    }
}
const options = {
  // 浏览器窗口
  screenSize: {
    width: 755,
    height: 25
  },
  // 要截图的页面文档区域
  shotSize: {
    height: 'all'
  },
  // 网页类型
  siteType: 'html'
};

回去按钮缺失问题

而web页面是以首先个页面的话,这时候会有一个题目,小序的回到按钮就无了,webview无法使用微信的回来按钮了,这时候要以webview页面前多加一个跳转页面就哼了(第一独页面吗堪设置成获用户权限的页面,不过自己感到这样感受不好,也非是有所页面都设用户得到了权力才得采用)

最后之页面层级

JavaScript

“pages”: [ “page/index/index”, //
首页,处理onload里之option内容,为了回按钮设置的 “page/home/index”, //
webview所在的页面 “page/auth/index”, // 获取用户权限的页面
“page/pay/index”, // 支付页面 “page/error/index” // 错误信息页面 ],

1
2
3
4
5
6
7
"pages": [
    "page/index/index", // 首页,处理onload里的option内容,为了返回按钮设置的
    "page/home/index", // webview所在的页面
    "page/auth/index", // 获取用户权限的页面
    "page/pay/index", // 支付页面
    "page/error/index" // 错误信息页面
  ],

这边,浏览器窗口的增幅要基于网页情况客观设置,高度可以设置为一个怪有些之数值,然后页面文档区域之高度肯定要是安装为all,宽度默认为窗口宽度,这样就是好把表格以极端小之尺寸完整截图。

参照链接

  1. webview文档
  2. 小程序unionid介绍
  3. unionid获得方式

    2 赞 2 收藏
    评论

图片 1

接下来,定义html字符串:

let html = "target rich text html code, eg: <table>...</table>";

只顾,里面的HTML代码一定要是失去丢换行符,并拿双双引号替换为单引号。

最后,截图:

webshot(html, 'demo.png', options, (err) => {
  if (err)
    console.log(`Webshot error: ${err.message}`);
});

然,就兑现了于HTML代码到地方图片的变,后续可以上传到七牛云等。不管是服务端的分析,还是稍微程序的展现,都没有什么难度了…

谢谢阅读,希望会帮忙到大家,谢谢大家对本站的支撑!

若或许感兴趣的篇章:

相关文章

标签:

发表评论

电子邮件地址不会被公开。 必填项已用*标注

网站地图xml地图