一、我的问题
在小程序中有一个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
那我现在遇到的问题就是前端如何生成签名?
【公众号平台 => 设置与开发 => 开发 => 基本配置】获取开发者ID(AppID)和开发者密码(AppSecret)
通过微信公众平台接口调试工具(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白名单 => 配置】
- 获取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