网站搜索框使用微信扫码功能

背景

客户要求可以直接识别标签二维码对某些仪器设备进行管理,类似于淘宝搜索框可以直接拍照搜索商品一样。前面已经做了一个网页调用摄像头识别二维码的功能,此功能有两个缺陷:

  • 识别需要先拍照,不能直接识别
  • 识别率低,尤其是拍照抖动,二维码内容稍微多一点或二维码小一点就识别不了。

以上两点相加就相当不好用了。

使用微信扫码

鉴于我们的系统已经集成到了微信公众号,所以准备调用微信扫码(只有在微信内打开的页面才能使用微信扫码)。
参照官方文档

绑定域名

打开公众号设置



选择功能设置



添加JS接口安全域名,注意你添加的域名目录下面上次图中微信指定的文件,如果文件没在根目录,域名需要填写到子目录


引入JS文件

使用vs2019创建默认的asp.net mvc项目

在index.cshtml页面中使用的页面引用js

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

前端主要代码

$(function () {
  /**
   * 判断是否微信内部打开页面
   * */
  function isWeiXin() {
    var ua = window.navigator.userAgent.toLowerCase();
    console.log(ua);//mozilla/5.0 (iphone; cpu iphone os 9_1 like mac os x) applewebkit/601.1.46 (khtml, like gecko)version/9.0 mobile/13b143 safari/601.1
    if (ua.match(/MicroMessenger/i) == 'micromessenger') {
      return true;
    }
    else {
      return false;
    }
  }
  /**
   * 只有微信内部页面打开才能用
   * */
  if (isWeiXin()) {
    $.ajax({
      type: "post",
      url: "/Home/GetSingDataAsync",
      data: {
        "url": location.href.split('#')[0]
      },
      dataType: "json",
      success: function (data) {
        alert(JSON.stringify(data));
        wx.config({
          debug: true, // 开启调试模式,调用的所有api的返回值会在客户端alert出来,若要查看传入的参数,可以在pc端打开,参数信息会通过log打出,仅在pc端时才会打印。
          appId: data.appId, // 必填,公众号的唯一标识
          timestamp: data.timestamp, // 必填,生成签名的时间戳
          nonceStr: data.nonceStr, // 必填,生成签名的随机串
          signature: data.signature,// 必填,签名,见附录1
          jsApiList: [
            'checkJsApi',
            'startRecord',
            'stopRecord',
            'translateVoice',
            'scanQRCode',// 微信扫一扫接口
            'openCard'
          ] // 必填,需要使用的JS接口列表,所有JS接口列表见附录2
        });
        wx.error(function (res) {
          alert("出错了:" + res.errMsg);//这个地方的好处就是wx.config配置错误,会弹出窗口哪里错误,然后根据微信文档查询即可。
        });
        wx.ready(function () {
          wx.checkJsApi({
            jsApiList: ['scanQRCode'],
            success: function (res) {
              //扫描二维码
              wx.scanQRCode({
                needResult: 1, // 默认为0,扫描结果由微信处理,1则直接返回扫描结果,
                scanType: ["qrCode"], // 可以指定扫二维码还是一维码,默认二者都有
                success: function (res) {
                  var result = res.resultStr; // 当needResult 为 1 时,扫码返回的结果
                  alert(result);//因为我这边是扫描后有个链接,然后跳转到该页面
                },
                error: function () {
                  console.log('123');
                }
              });
            }
          });
        });
      },
      error: function (url) {
        alert("An error occurred!");
      }
    });
  } else {
    alert("请使用微信打开");
  }
}) 
      

内容版权声明:除非注明,否则皆为本站原创文章。

转载注明出处:http://www.heiqu.com/1520.html