vue企业微信获取经纬度腾讯地图逆向解析详细地址

在这里插入图片描述摘要:

今天做企业微信打卡小应用的时候,使用到调用企业微信内置sdk来获取当前经纬度,想到企业微信还是使用腾讯地图逆向解析详细地址比较准确一点,使用使用腾讯地图来解析详细地址!

在获取微信定位的时候,要先通过config接口注入权限验证配置,获取配置信息里面的内容是后端接口给出的,所用的接口域名一定要备案。一般是请求后端接口获取签名的!与后端沟通好就okk!!!

企业微信开发文档

let code = this.getQueryVariable("code");
      this.codes = code;
      if (/wxwork/i.test(navigator.userAgent)) {
        if (!!code) {
          if (/Android|webOS|iPhone|iPod|BlackBerry/i.test(navigator.userAgent)) {
            this.wxwork();
            this.wxDefaultBrowser();
            return;
          }
        } else {
          // 正式
          window.location.replace(
            'https://open.weixin.qq.com/connect/oauth2/authorize?appid=xxxxxxx&redirect_uri=https%3A%2F%2Fxxx.xxxx.com%2FclockingApp%2Fpindex.html&response_type=code&scope=snsapi_base&state=STATE#wechat_redirect'
          )
          // 测试
          // window.location.replace(
          //   "https://open.weixin.qq.com/connect/oauth2/authorize?appid=xxxxxxxx&redirect_uri=http%3A%2F%2Ftestxxx.xxxx.com:20080%2Fpindex.html&response_type=code&scope=snsapi_base&state=STATE#wechat_redirect"
          // );
        }
        return;
      }

进入页面获取登录信息,拉取code进行登录校验,然后根据回来的token去请求数据,定位获取经纬度后期解析详细地址!

wxDefaultBrowser() {
        let url = window.location.href.split("#")[0];
        let that = this;
        that.$axios
          .get("/commonNoSession.do", {
            params: {
              method: that.$method.XXXX_XXXX_WECHAT_TOKEN_GET,
              data: {
                url: url,
                appKey: "corpid",
              },
            },
          })
          .then((res) => {
            Toast.loading({
              message: '加载中...',
              forbidClick: true,
            });
            if (res.data.code == 0) {
                wx.config({
                  beta: true, // 必须这么写,否则wx.invoke调用形式的jsapi会有问题
                  debug: false,
                  appId: res.data.data.appId,
                  timestamp: res.data.data.timestamp,
                  nonceStr: res.data.data.noncestr,
                  signature: res.data.data.signature,
                  jsApiList: ["getLocation"], // 必填,需要使用的JS接口列表,凡是要调用的接口都需要传进来
                });
                wx.ready(function() {
                  wx.getLocation({
                      type: 'gcj02',
                      success: function (res) {
                        var latLng = new qq.maps.LatLng(res.latitude, res.longitude)
                        getAddr.getAddress(latLng)
                      },
                      fail: function (response) {
                        alert("请先打开手机定位刷新页面再打卡~");
                      },
                  });
                  wx.error(function (res) {
                      console.log('微信js-sdk 配置失败000' + res.errMsg)
                      // alert('微信js-sdk 配置失败000' + res.errMsg)
                  })
                });
                var getAddr = new qq.maps.Geocoder({
                    complete: function (res) {
                      alert(JSON.stringify(res))
                      var allAddress = res.detail;//成功回调详细地址
                    }
                })
            }
          })
          .catch((error) => {});
      },

获取签名wx.config企业微信注入权限,wx.getLocation获取准确的经纬度,然后调取腾讯地图qq.maps.Geocoder逆向解析详细地址!
记得index.html引入相关sdk:

<!DOCTYPE html>
<html>
  <head>
    <meta charset="utf-8">
    <meta name="viewport" content="width=device-width,initial-scale=1,user-scalable=0">
    <title>打卡</title>
  </head>
  <body>
    <div id="app-box"></div>
    <script src="https://res.wx.qq.com/open/js/jweixin-1.2.0.js"></script>
    <script src="https://open.work.weixin.qq.com/wwopen/js/jwxwork-1.0.0.js"></script>
    <script charset="utf-8" src="https://map.qq.com/api/js?v=2.exp&key=OB4BZ-D4W3U-B7VVO-4PJWW-6TKDJ-WPB77"></script>
  </body>
</html>

遇到的坑:
在这里插入图片描述
调用wx.getLocation使用wgs84时获取回来的经纬度腾讯地图解析出来的详细地址好像相差一公里,特别不正确的!所以使用了火星坐标gcj02,高级,就是回来的address带有中国!难道可以定位外国去???

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值