一些H5对接微信JSSDK的问题记录

这里给大家分享我在实际生活中总结出来的一些知识,希望对大家有所帮助

一.SDK引入

这里提供两套引入流程,一套是vue2.0及其他h5项目,一套是vue3.0的引入流程

不懂的也可以看我之前的一篇详细流程

记录--微信调用jssdk全流程详解

1.js引入

直接在你的页面里引入js文件就行

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

2.weixin-js-sdk引入

先调用全局命令

npm install weixin-js-sdk

然后修改main.js,加上以上代码

import wx from "weixin-js-sdk"
import {
	createSSRApp
} from 'vue'
export function createApp() {
	const app = createSSRApp(App)
	app.config.globalProperties.$wx=wx;
	return {
		app
	}
}

之后在调用的页面直接$wx引入就行了

二.代码引用流程

基础代码引用逻辑如下,需要我们在jsApiList中添加我们要的权限,然后调用对应的wx接口,这里以定位权限为例

var wxNavigation = (data) => {
	return new Promise((resolve, reject) => {
		wx.config({
			debug: false, // 开启调试模式,调用的所有api的返回值会在客户端alert出来,若要查看传入的参数,可以在pc端打开,参数信息会通过log打出,仅在pc端时才会打印。
			appId: data.appId, // 必填,公众号的唯一标识
			timestamp: data.timestamp, // 必填,生成签名的时间戳
			nonceStr: data.nonceStr, // 必填,生成签名的随机串
			signature: data.signature, // 必填,签名
			jsApiList: ["getLocation"],// 必填,需要使用的JS接口列表
		});
		wx.ready(() => {
			wx.getLocation({
				type: "gcj02", // 默认为wgs84的gps坐标,如果要返回直接给openLocation用的火星坐标,可传入'gcj02'
				success: function(res) {
					resolve({
						bor: true,
						data: res,
					});
				},
			});
		});
	});
};

 三,报错处理

这里分享三个我经常遇到的报错

1.xxxx: the permission value is offline verifying

这个报错是最常见的,是因为 config 没有正确执行,或者是调用的 JSAPI 没有传入 config 的jsApiList参数中。建议按如下顺序检查:

确认 config 正确通过。
如果是在页面加载好时就调用了JSAPI,则必须写在wx.ready的回调中。
确认 config 的jsApiList参数包含了这个JSAPI。

2.开发者工具config:ok 手机getLocation:invalid signature?

这个是在调用getLocation,wxOpenLocation等定位,打开导航类型的接口时会出现的问题,原因就是接口权限比较高,如果换页面调用了,没有请求当前页面的url,就会导致invalid signature,一般是要重新请求一次jsSDK就没问题了,这里提供我的两套思路

getLocation

问题描述和解析

ios使用微信自带方法wx.getLocation调取用户地理位置,会直接走err,输出报错是“‘getLocation:invalid signature’”

但是安卓机就没这个问题。

我看有人说
调接口获取wx.config配置所需参数的入参(页面路径),ios没有获取到最新的
于是我在app.vue里进入页面时,将当前的路径缓存起来,在自己掉位置的页面里使用。
但是解决不了我的问题

后来我看到了网上说ios刷新就能成功,我就测试了一下 ,果然是可以调用成功了!!!
然后也百度了好多,说是这个是ios本身就有这个问题。

最后在wx.ready里加了一个刷新一次页面的方法,就没问题了

代码思路:

  wx.config({
				debug: false,
				appId: data.appId,
				timestamp: data.timestamp,
				nonceStr: data.nonceStr,
				signature: data.signature,
				jsApiList: ["getLocation", "openLocation"],
			});
			wx.ready(() => {
				wx.getLocation({
					type: type, // 默认为wgs84的gps坐标,如果要返回直接给openLocation用的火星坐标,可传入'gcj02'
					success: function(res) {
						
					},
					fail: function(err) {
						const u = navigator.userAgent;
						const iOS = !!u.match(/\(i[^;]+;( U;)? CPU.+Mac OS X/);
						if (iOS) {
							window.location.reload();
						}
						console.log('返回默认地址')
						
					},
				});
			});

 wxOpenLocation

问题描述

在调用了wxopenlocation时,调试返回结果正常,但是就是打不开地图,一般是经纬度没有使用浮点类型,如果使用了后还出现这个问题,就需要我们在调用时用延时调用,来防止我们的代码在内存运行的时候反应不过来

 代码思路

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

 3.禁止分享代码失效

问题描述

在我们需要让全局的所有页面禁止微信复制,分享朋友圈等功能时,莫名奇妙刷新后就又可以分享了,这里提供我的解决方案,在main.js或所有页面的初始化文件中调用以下代码,直接去除微信分享类目的所有功能

 代码思路

const hideShare = (data)=>{
	return new Promise((resolve, reject) => {
		wx.config({
			// debug: true,
			appId: data.appId,
			timestamp: data.timestamp,
			nonceStr: data.nonceStr,
			signature: data.signature,
			jsApiList: ['hideOptionMenu','hideAllNonBaseMenuItem','hideMenuItems'],
		});
		wx.ready(() => {
			wx.hideOptionMenu();
			wx.hideAllNonBaseMenuItem();
			wx.hideMenuItems({// 要隐藏的菜单项,只能隐藏“传播类”和“保护类”按钮,所有menu项见附录3
				menuList: [
					'menuItem:share:appMessage', //发送给朋友
					'menuItem:share:timeline', //分享到朋友圈
					'menuItem:copyUrl' //复制链接
				]
			})
		});
	});
}

以上就是我在对接微信JSSDK中碰到的一些问题,如果对您有所帮助,欢迎您点个关注,我会定时更新技术文档,大家一起讨论学习,一起进步。

 

### 实现 uni-app 中 H5 页面通过 JSSDK 扫码功能 #### 准备工作 为了使微信 JSSDK 正常运行,在 `index.html` 文件中需引入 jweixin 库并处理命名冲突: ```html <script src="https://res.wx.qq.com/open/js/jweixin-1.6.0.js"></script> <script> window.jWeixin = window.wx; delete window.wx; </script> ``` 此操作确保了全局对象 wx 不会与其他库发生冲突[^2]。 #### 配置服务器端签名算法 服务端需要提供接口来获取 jsapi_ticket 并计算 signature 参数。具体实现依赖于后端技术栈,但核心逻辑保持一致:基于当前 URL 和 ticket 计算 SHA1 值作为签名。 #### 客户端初始化配置 在 Vue 组件生命周期钩子 created 或 mounted 方法里调用微信 JS-SDK 的 config 接口完成环境准备: ```javascript export default { data() { return {}; }, methods: { initWxConfig(configData) { // 初始化微信JS-SDK配置 jWeixin.config({ debug: false, // 开启调试模式, appId: configData.appId, // 必填,企业号的唯一标识 timestamp: configData.timestamp, // 必填,生成签名的时间戳 nonceStr: configData.nonceStr, // 必填,生成签名的随机串 signature: configData.signature,// 必填,签名 jsApiList: ['scanQRCode'] // 必填,需要使用的JS接口列表 }); jWeixin.ready(function(){ console.log('wx ready'); }); jWeixin.error(function(res){ alert(JSON.stringify(res)); }); } }, onLoad(option) { const url = encodeURIComponent(location.href.split('#')[0]); // 调用后端API获取config数据 this.$http.get(`/wechat/config?url=${url}`).then((response)=>{ let result=response.data; if(result.code===0){ this.initWxConfig(result.data); }else{ console.error("Failed to get wechat config"); } }).catch(err=>{ console.error(`Error occurred while fetching WeChat config ${err}`); }) } } ``` 上述代码片段展示了如何向服务器请求必要的参数,并利用这些参数对 JSSDK 进行初始化设置[^1]。 #### 发起扫描动作 当用户触发特定事件时(比如点击按钮),可以执行如下 JavaScript 来启动二维码扫描过程: ```javascript methods:{ scanQrCode:function(){ jWeixin.scanQRCode({ needResult: 1, // 默认为0,扫描结果由微信处理;1则直接返回扫描结果给前端应用 desc : 'scanQRCode desc', // 可选,默认为空字符串 success: function (res) { var result = res.resultStr; // 当needResult 为 1 时有效 console.log("Scan Result:",result); }, fail:function(error){ console.warn("Scan failed",error); } }); } } ``` 这段脚本定义了一个名为 `scanQrCode()` 的方法用于激活摄像头进行 QR Code 扫描,并接收回调函数中的识别结果。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值