这篇文章主要讲解了js中如何实现调用微信的扫描二维码功能,内容清晰明了,对此有兴趣的小伙伴可以学习一下,相信大家阅读完之后会有帮助。
关键代码
<html>
<head>
<title>
js调用微信扫一扫功能测试
</title>
<!--引用微信JS库-->
<script type="text/javascript" src="http://res.wx.qq.com/open/js/jweixin-1.0.0.js"></script>
<!--引用jQuery库-->
<script type="text/javascript" src="http://code.jquery.com/jquery-1.4.2.min.js"></script>
</head>
<body>
<input type="button" value="扫一扫" id="scanQRCode">
<script type="text/javascript">
//这里【url参数一定是去参的本网址】
$.get("获取微信认证参数的网址?url=当前网页的网址", function(data){
var jsondata=$.parseJSON(data);
wx.config({
// 开启调试模式,调用的所有api的返回值会在客户端alert出来,若要查看传入的参数,可以在pc端打开,参数信息会通过log打出,仅在pc端时才会打印。
debug: false,
// 必填,公众号的唯一标识
appId: jsondata.model.appId,
// 必填,生成签名的时间戳
timestamp: "" + jsondata.model.timestamp,
// 必填,生成签名的随机串
nonceStr: jsondata.model.nonceStr,
// 必填,签名
signature: jsondata.model.signature,
// 必填,需要使用的JS接口列表
jsApiList: ['checkJsApi', 'scanQRCode']
});
});
wx.error(function (res) {
alert("出错了:" + res.errMsg);//这个地方的好处就是wx.config配置错误,会弹出窗口哪里错误,然后根据微信文档查询即可。
});
wx.ready(function () {
wx.checkJsApi({
jsApiList: ['scanQRCode'],
success: function (res) {
}
});
//点击按钮扫描二维码
document.querySelector('#scanQRCode').onclick = function () {
wx.scanQRCode({
needResult: 1, // 默认为0,扫描结果由微信处理,1则直接返回扫描结果,
scanType: ["qrCode"], // 可以指定扫二维码还是一维码,默认二者都有
success: function (res) {
var result = res.resultStr; // 当needResult 为 1 时,扫码返回的结果
alert("扫描结果:"+result);
window.location.href = result;//因为我这边是扫描后有个链接,然后跳转到该页面
}
});
};
});
</script>
</body>
</html>
注意事项:
“获取微信认证参数”
这个的前提是您能够有自己的微信开发资质,并能获取到正确的参数
- 公众号的唯一标识
- 签名的时间戳
- 签名随机串
常见的错误
config:invalid signature
解决办法
“当前网页的地址”-----哈哈,一定是你写的不对,这里一定是去参的本网页的地址
最好是在服务器下去测试
看完上述内容,是不是对js中如何实现调用微信的扫描二维码功能有进一步的了解,如果还想学习更多内容,欢迎关注天达云行业资讯频道。