微信小程序webview中如何使用微信JS接口

一、我的问题

在小程序中有一个webview页面内嵌了h5,在h5页面中,我想要通过wx.getLocation如何获取位置信息?
一开始我以为它跟抖音和百度小程序一样,只需要引入一个sdk地址,就可以直接使用webview中可支持的方法了。然而微信并不是!!会直接报错getLocation:fail, the permission value is offline verifying

二、解决办法

官方给出了答案如下:



但是我一个新手,每句话都能认识,却不知道怎么操作!
而且我有一个疑惑,这是微信公众号中的文档,是否小程序也应该如此操作?带着这个疑惑,我开始尝试一番!
接下来直接描述步骤吧:

1、引入js sdk文件

<script src="https://res.wx.qq.com/open/js/jweixin-1.3.2.js" ></script>

2、配置wx.config

wx.config({
  debug: false, // 开启调试模式,调用的所有api的返回值会在客户端alert出来,若要查看传入的参数,可以在pc端打开,参数信息会通过log打出,仅在pc端时才会打印。
  appId: 'wx45xx44xx9a3af6e0', // 必填,公众号的唯一标识
  timestamp: '1720057075', // 必填,生成签名的时间戳
  nonceStr: 'Wm3WZYTPz0wzccnW', // 必填,生成签名的随机串
  signature: 'b723697febbc7b0286b0d740b6b16dbea6b44e1f',// 必填,签名
  jsApiList: ["getLocation"] // 必填,需要使用的JS接口列表
});

①. 需要公众号安全域名配置

【公众号平台 => 设置与开发 => 公众号设置 => 功能设置 => JS接口安全域名】

②. 获取wx.config所需参数

appId,timestamp ,nonceStr,signature这几个参数,其实都需要通过后端给我们,但是目前我不确定这种方案是否可行,所以我需要自己先验证一下。
签名算法官方文档参考:https://developers.weixin.qq.com/doc/offiaccount/OA_Web_Apps/JS-SDK.html#%E9%99%84%E5%BD%951-JS-SDK%E4%BD%BF%E7%94%A8%E6%9D%83%E9%99%90%E7%AD%BE%E5%90%8D%E7%AE%97%E6%B3%95
那我现在遇到的问题就是前端如何生成签名?

  1. 【公众号平台 => 设置与开发 => 开发 => 基本配置】获取开发者ID(AppID)和开发者密码(AppSecret)

  2. 通过微信公众平台接口调试工具(https://mp.weixin.qq.com/debug/cgi-bin/apiinfo)获取access_token(有效期2小时)

{
    "grant_type": "client_credential", 
    "appid": "wx59xxxxxxxxaf6e0",  // 注意一定是公众号id
    "secret": "b892exxxxxxxxxxxxxxxxcd444500046e3"
}

注意:获取access_token过程应该会遇到一个ip不在白名单的报错,可以按如下路径去公众号添加白名单:
【公众号平台 => 设置与开发 => 基本配置 => 公众号开发信息 => IP白名单 => 配置】

  1. 获取jsapi_ticket(https://api.weixin.qq.com/cgi-bin/ticket/getticket?access_token=ACCESS_TOKEN&type=jsapi

4.使用微信 JS 接口签名校验工具(https://mp.weixin.qq.com/debug/cgi-bin/sandbox?t=jsapisign)计算签名

最后生成的签名和其他参数在wx.config()中调试即可。

3、在wx.ready调用方法

wx.ready(() => {
      wx.getLocation({
          type: "gcj02",
          success: async res => {
            console.log("getLocation调用成功", res);
          },
          fail: err => {
            console.log(`getLocation调用失败`, err);
          }
        });
});

这个时候差不多大功告成,终于能获取到位置信息啦。

tips: 文中提到的appid和AppSecret都是公众号的(个人就在这被坑了很长时间),所以小程序中webview内要用到这些方法,还必须要有一个公众号的可以使用,我这里是自己个人注册了一个订阅号去尝试的

wx.config打通了之后,不只是能调用getLocation的方法,比如常用到的分享接口都是需要先进行这一步的。
支持的方法可以看文档https://developers.weixin.qq.com/doc/offiaccount/OA_Web_Apps/JS-SDK.html#63

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

推荐阅读更多精彩内容