使用vue框架搭建浙里办微应用(单点登录、埋点、适老化、RPC网关)

1、前期准备:

浙里办对接h5官方开发文档: https://odynww.yuque.com/docs/share/525e3e8a-ad52-421b-90da-2d76808e3050?

H5前端源代码包(编译前 支持npm run build) 部署在应用开发管理平台 。服务端代码包 部署在应用自有服务器。前后端分离,服务端透出的API接口通过注册在应用开发管理平台API网关(RPC接入) 向部署前端H5应用提供接口服务(API网关入参没有文件类型,文件上传接口可自行实现,保障可用)。如应用有使用单点登录能力 回调地址 需要使用 应用开发管理平台 线上环境访问地址拼接回调。

1.1、由于浙里办编译默认输出位置是build,但是vue的构建命令默认输出位置是dist。我的解决办法是在项目的根目录下新建gbc.json文件向浙里办指定输出目录

image.png
{
  "type":"gov-build-config",
  "version":"1",
  "outputPath":"dist",
  "entryHtml": "/index.html"
}

1.2、由于前端项目部署在浙里办服务器上,所以还需要对vite.config.js文件进行如下修改(注:不同的框架解决办法可能不一样,本项目是使用的vue3+vite)

image.png

如果是Uniapp项目的话,

{
    "name" : "xxxxxxxx",
    "appid" : "",
    "description" : "",
    "versionName" : "1.0.0",
    "versionCode" : "100",
    "transformPx" : false,
    "h5" : {
        "publicPath" : "./", // 修改1 不修改此处会出现应用白屏的情况
        "router" : {
            "base" : "./", // 修改2 不修改此处会出现图片拿不到的情况
            "mode" : "hash" // 修改3 浙里办只支持hash路由
        }
    }
}

二、浙里办-单点登录功能

由于浙里办微应用需要对支付宝浙里办小程序与浙里办APP进行双端适配,而不同环境下的单点登录跳转链接也不同,所以需要进行应用环境的检测

 let sUserAgent = window.navigator.userAgent.toLowerCase()
 let bIsDtDreamApp = sUserAgent.indexOf('dtdreamweb') > -1 // 浙里办APP
 let bIsAlipayMini = sUserAgent.indexOf('miniprogram') > -1 && sUserAgent.indexOf('alipay') > -1//支付宝浙里办小程序

2.1主要代码实现:

在mounted()方法中判断有没有ticket来判断是否进行登录

getTicket() {
   var url = window.location.href// 获取页面路由
   if (url.indexOf('ticket') != -1) {
      this.ticket = url.split('=')[2].split('#')[0]
   }
  //如果有票据的话那么进行获取个人信息操作,如果没有的话那么进行登录
   if (this.ticket != '') {
     this.getZLBuserInfo()
  } else {
     // 先登录 判断当前所处环境
     this.loginFun()
    }
 },

注:接入码是跟浙里办申请服务接入通过之后给的,goto参数是单点登录跳转的回调地址,如果不指定就以后台设置的sp参数作为回调地址跳转。(sp参数自己无权限修改,必须找服务接入对接人设置,且不设置单点登录登录成功将显示“无权访问业务系统”的提示字样)

loginFun() {
   if (bIsDtDreamApp) {
window.location.replace(`https://puser.zjzwfw.gov.cn/sso/mobile.doaction=oauth&scope=1&servicecode=jkxw`) 
}
 else if (bIsAlipayMini) {
      window.location.replace(`https://puser.zjzwfw.gov.cn/sso/alipay.do?action=ssoLogin&servicecode=jkxw`)
     }
},

三、配置RPC网关依赖后续进行个人信息的获取

这里是可以和后台配合进行个人信息的获取,但是当时公司后台忙不过来,就在政务中台研究一下使用RPC网关调用实现个人信息的获取。

3.1 首先需要在浙里办的中控新建一个RPC系统

image.png

3.2 新建API

image.png

3.3 填写API基本信息,其中API名称是之后需要调用的参数

image.png

3.4 填写服务信息,目标地址均填写:https://appapi.zjzwfw.gov.cn/sso/servlet/simpleauth

image.png

3.5 填写参数映射关系,传参方式选择query透传,入参和途图中设置一致

image.png

3.6 出参按照自己的需求进行设置即可,基本类型,String类型,名称与原浙里办SSO接口规范一致,按需增减即可。其中框选参数必选,后续埋点需要用到。

image.png

3.7 设置完成API以后,点击上线即可在前端使用网关API进行调用。上线后如需修改,点击升级即可重新编辑。(先点击上线,然后提交审核,审核通过之后会显示已上线)

image.png

3.8 设置完成api之后,接入服务:(先点击“去接入”,接入成功之后会显示接入服务个数)

image.png

3.9 设置网关白名单

image.png

四、获取个人信息

4.1首先要安装网管依赖

 npm i --save @aligov/jssdk-mgop@3.0.0

4.2 在登录页进行调用

import { mgop } from '@aligov/jssdk-mgop';
getZLBuserInfo() {
        this.getTonkenAndUserInfo(this.getTonkenAndUserInfoParams()).then(data => {
          return this.getTonkenAndUserInfo(this.getTonkenAndUserInfoParams('getUserInfo', data.token))
        }).then(data => {
          // console.log('---------------浙里办返回的userInfo-----------------')
          this.setZlbUserInfo(data)
          //浙里办用户信息设置埋点
          this.setUserAplus(data)
          this.setLoading(true)
          this.login({
            idcard: data.idnum,
            name: data.username,
            tel: data.mobile,
            callback: (res) => {
              // console.log(res)
              this.setLoading(false)
              this.$router.push('/health/archives')
            },
          })
        }).catch(err => {
          console.log(err)
        })
      },
 getTonkenAndUserInfo(data) {
        return new Promise((resolve, reject) => {
          mgop({
            api: 'mgop.yzh.home.ticket',
            host: 'https://mapi.zjzwfw.gov.cn/',
            data: data,
            dataType: 'JSON',
            type: 'POST',
            appKey: this.appKey,
            onSuccess: res => {
              if (res.data.result && res.data.result == 0) {
                resolve(res.data)
              }
            },
            onFail: err => {
              reject(err)
            }
          })
        })
      },
      getTonkenAndUserInfoParams(method = 'ticketValidation', token = '') {
        let mTime = this.timeFormat(new Date(), 'yyyymmddhhMMss')
        let data = {
          method: method,
          servicecode: this.servicecode,
          time: mTime,
          sign: this.$md5(`${this.servicecode}${this.servicePassword}${mTime}`),
          datatype: 'json'
        }
        if (token == '') {
          data.st = this.ticket
        } else {
          data.token = token
          this.zlbToken = token
        }
        return data
      },
      getLocation() {
        ZWJSBridge.getLocation().then((result) => {
          this.userLocation = result
        }).catch((error) => {
          console.log(error)
        })
      },

4.3 浙里办j基础信息埋点和用户信息埋点

基础埋点放在Index.html中(这一段照抄就行)

 <script>
    (function(w, d, s, q, i) {
      w[q] = w[q] || [];
      var f = d.getElementsByTagName(s)[0],
        j = d.createElement(s);
      j.async = true;
      j.id = 'beacon-aplus';
      j.src = 'https://d.alicdn.com/alilog/mlog/aplus.js?id=202951085';
      f.parentNode.insertBefore(j, f);
    })(window, document, 'script', 'aplus_queue')
    aplus_queue.push({
      action: 'aplus.setMetaInfo',
      arguments: ['aplus-waiting', 'MAN']
    });
    aplus_queue.push({
      action: 'aplus.setMetaInfo',
      arguments: ['aplus-rhost-v', 'alog.zjzwfw.gov.cn']
    });
    aplus_queue.push({
      action: 'aplus.setMetaInfo',
      arguments: ['aplus-rhost-g', 'alog.zjzwfw.gov.cn']
    })
    aplus_queue.push({
      action: 'aplus.setMetaInfo',
      arguments: ['appId', '60506758']
    })
    aplus_queue.push({
      action: 'aplus.setMetaInfo',
      arguments: ['_hold', 'BLOCK']
    })
  </script>

用户信息的埋点(用户的username、userid、用户的经纬度和用户类型)

//浙里办用户信息设置埋点
      setUserAplus(userInfo) {
        // 设置用户信息埋点
        aplus_queue.push({
          action: 'aplus.setMetaInfo',
          arguments: ['_user_nick', userInfo.username]
        })
        aplus_queue.push({
          action: 'aplus.setMetaInfo',
          arguments: ['_user_id', userInfo.userid]
        })
        aplus_queue.push({
          'action': 'aplus.sendPV',
          'arguments': [{
            is_auto: false
          }, {
            miniAppId: '2001936819',
            miniAppName: '健康小屋',
            long: this.userLocation.longitude,
            lati: this.userLocation.latitude,
            userType: this.userType,
          }]
        })
        aplus_queue.push({
          action: 'aplus.setMetaInfo',
          arguments: ['_hold', 'START']
        })
      },

获取用户经纬度和用户的类型

 getLocation() {
        ZWJSBridge.getLocation().then((result) => {
          this.userLocation = result
        }).catch((error) => {
          console.log(error)
        })
      },
      getUserType() {
        ZWJSBridge.getUserType().then((result) => {
          // console.log(result, 'userType---------')
          this.userType = result.userType
        }).catch((error) => {
          console.log(error)
        })
      },

4.4、AppId、AppName及AppKey参数位置

image.png

5、二次回退(所谓的二次回退指的是可以用户在应用首页需要点击两次才可以回到浙里办首页)

这里我是在正确获取用户信息之后,跳转到档案页,此处必须用push!!!这是我跳得坑!!


image.png

我的解决办法是在路由配置文件中给两个页面配置meta,然后在beforeRouteEnter中进行监听,如果监听到是从首页返回的话,就调用浙里办api和支付宝api进行关闭自己的应用。
具体实现:


image.png

在路由配置文件中:


image.png

在浙里办login页监听到用户从档案页点击返回的时候就调用api关闭:


image.png

6、适老化(适老化是浙里办上架h5硬性要求的,必须做)

我用的是vuex中存储一个变量,在登录页判断当前系统的uityle,然后设置vuex中的uistyle变量的值


image.png

在单点登录页:


image.png

在页面上获取vuex中的uistyle变量,从而选择使用哪一个选择器


image.png

image.png
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,616评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,020评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,078评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,040评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,154评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,265评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,298评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,072评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,491评论 1 306
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,795评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,970评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,654评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,272评论 3 318
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,985评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,223评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,815评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,852评论 2 351

推荐阅读更多精彩内容