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

 更新时间:2019年08月15日 15:53:48   作者:小神仙  
客户要求可以直接识别标签二维码对某些仪器设备进行管理,类似于淘宝搜索框可以直接拍照搜索商品一样。接下来通过本文给大家分享网站搜索框使用微信扫码功能,需要的朋友可以参考下

背景

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

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

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

使用微信扫码

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

绑定域名

打开公众号设置



选择功能设置



添加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("请使用微信打开");
  }
}) 

后端代码

public class HomeController : Controller
{
  //把APPID和APP_SECRET换成你自己的
  private const string APPID = "******";
  private const string APP_SECRET = "******";
  //为了调试方便我这里第一次把Token和Ticket获取到之后就写死了,应该写入缓存(7200s过期)
  private static string Token = "24_cQsz9scwyXLnPaAes5JlfHTfuQ2e3Iw5L8JyWfUpQiMnTk4IToOTZ7dP0Fv190ZHTy5ST--jeuDzYwoUj_hvhSHDX288YYLYVcrmvMzRPwld8ccTTzWGNTKZz53jYKDy5f8U1E886msDPsrwORGbAJABET";
  private static string Ticket = "HoagFKDcsGMVCIY2vOjf9qZA_fkPP3enjnT58qu16hzZN-3kwAP0NK6jgQM0jyAc0sK8cxaGkT9_DSgp6cHCpw";
  public ActionResult Index()
  {

    return View();
  }

  public ActionResult About()
  {
    ViewBag.Message = "Your application description page.";

    return View();
  }

  public ActionResult Contact()
  {
    ViewBag.Message = "Your contact page.";

    return View();
  }


  public async Task GetToken()
  {
    await GetTicketAsync();
  }
  //获取token和ticket
  private async Task<string> GetTicketAsync()
  {

    var tokenUrl = $"https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid={APPID}&secret={APP_SECRET}";

    var client = new System.Net.WebClient();
    client.Encoding = Encoding.UTF8;
    client.Headers.Add("Content-Type", "Application/x-www-form-urlencoded");
    var responseData = client.UploadData(tokenUrl, "POST", new byte[0]);
    var responseText = Encoding.UTF8.GetString(responseData);
    var token = JsonConvert.DeserializeAnonymousType(responseText, new { access_token = "", expires_in = "" });


    Token = token.access_token;
    var ticketUrl = $"https://api.weixin.qq.com/cgi-bin/ticket/getticket?access_token={Token}&type=jsapi";
    var ticResponseData = client.UploadData(ticketUrl, "POST", new byte[0]);
    var ticResponseText = Encoding.UTF8.GetString(ticResponseData);
    var ticket = JsonConvert.DeserializeAnonymousType(ticResponseText, new { errcode = "", errmsg = "", ticket = "", expires_in = "" });
    Ticket = ticket.ticket;
    return "";
  }
  //获取签名字符串
  public async Task<string> GetSingDataAsync(string url)
  {

    var sign = new SignData();
    sign.appId = APPID;
    sign.nonceStr = Create_nonce_str();
    sign.timestamp = Create_timestamp();
    //var url = Request.Url.AbsoluteUri;
    if (url.IndexOf('#') > 0)
    {
      url = url.Substring(0, url.IndexOf('#'));
    }
    sign.url = url;
    var string1 = "jsapi_ticket=" + Ticket +
        "&noncestr=" + sign.nonceStr +
        "&timestamp=" + sign.timestamp +
        "&url=" + sign.url;

    //var string1 = GetTestSign();

    var sha1 = SHA1.Create();
    sign.signature = ByteToHex(sha1.ComputeHash(Encoding.UTF8.GetBytes(string1)));
    return JsonConvert.SerializeObject(sign);
  }
  //测试签名字符串,和微信官方提供的一样,用来测试签名方法是否正确
  private string GetTestSign()
  {
    var nonceStr = "Wm3WZYTPz0wzccnW";
    var ticket = "sM4AOVdWfPE4DxkXGEs8VMCPGGVi4C3VM0P37wVUCFvkVAy_90u5h9nbSlYy3-Sl-HhTdfl2fzFy1AOcHKP7qg";
    var timestamp = "1414587457";
    var url = "http://mp.weixin.qq.com?params=value";
    var string1 = "jsapi_ticket=" + ticket +
        "&noncestr=" + nonceStr +
        "&timestamp=" + timestamp +
        "&url=" + url;
    return string1;
  }

  /// <summary>
  /// 随机字符串
  /// </summary>
  /// <returns></returns>
  private string Create_nonce_str()
  {
    return Guid.NewGuid().ToString().Substring(0, 8);
  }
  /// <summary>
  /// 时间戳
  /// </summary>
  /// <returns></returns>
  private string Create_timestamp()
  {
    return (DateTime.Now.Ticks / 100000000).ToString();
  }
  private string ByteToHex(byte[] hash)
  {
    var sb = new StringBuilder();
    foreach (var b in hash)
    {
      sb.Append(b.ToString("x2"));
    }
    return sb.ToString();
  }
}

代码已上传github

总结

以上所述是小编给大家介绍的网站搜索框使用微信扫码功能,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持!
如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!

相关文章

  • 各种语言常用的一句话判断代码

    各种语言常用的一句话判断代码

    提供各种语言常用的一句话判断代码:一句话就能判断是不是含有中文、一句话就能判断是不是纯数字、一句话就能判断是不是闰年、一句话就能判断记录分多少页
    2013-03-03
  • UE、UI、UCD、Interaction Design、UED、UX、HCI、Usability,IA

    UE、UI、UCD、Interaction Design、UED、UX、HCI、Usability,IA

    最近,总是缠绵在UE、UI、UCD、Interaction Design、UED、UX、HCI、Usability,IA等等名词间,我一边搜集,一边整理,现在放在一次统一解释,以便比较,以正视听。很多地方未必准确,欢迎提出修改意见。
    2009-04-04
  • 利用二进制文件安装etcd的教程详解

    利用二进制文件安装etcd的教程详解

    etcd组件作为一个高可用强一致性的服务发现存储仓库.这篇文章主要介绍了利用二进制文件安装etcd的教程详解,需要的朋友可以参考下
    2019-08-08
  • bs架构和cs架构的区别_动力节点Java学院整理

    bs架构和cs架构的区别_动力节点Java学院整理

    这篇文章主要介绍了bs架构和cs架构的区别,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-07-07
  • DVWA下载、安装、使用(漏洞测试环境搭建)的详细教程

    DVWA下载、安装、使用(漏洞测试环境搭建)的详细教程

    这篇文章主要介绍了DVWA下载、安装、使用(漏洞测试环境搭建)的详细教程,本文通过图文并茂的形式给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-10-10
  • SSL常用专业缩略语汇总

    SSL常用专业缩略语汇总

    这篇文章主要介绍了SSL常用专业缩略语汇总,需要的朋友可以参考下
    2017-09-09
  • Loongnix安装PyCharm Community 2020.2.3的教程详解

    Loongnix安装PyCharm Community 2020.2.3的教程详解

    这篇文章主要介绍了Loongnix安装PyCharm Community 2020.2.3的教程详解,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-11-11
  • DataGrip 2020.1 安装与激活方法

    DataGrip 2020.1 安装与激活方法

    DataGrip是一款数据库管理客户端工具,方便连接到数据库服务器,执行sql、创建表、创建索引以及导出数据等。这篇文章主要介绍了DataGrip 2020.1 安装与激活教程,需要的朋友可以参考下
    2020-09-09
  • Intellij idea2020永久破解,亲测可用!!!

    Intellij idea2020永久破解,亲测可用!!!

    随着 IDEA 的 2020 版本的发布,新增和优化了很多的功能,今天来讲一讲如何永久破解,亲测可用,对idea2020永久破解 教程感兴趣的朋友可以跟随小编一起看看吧
    2020-05-05
  • vscode安装使用的详细教程

    vscode安装使用的详细教程

    Visual Studio Code (简称 VS Code / VSC) 是一款免费开源的现代化轻量级代码编辑器,这篇文章主要介绍了vscode安装使用的详细教程,需要的朋友可以参考下
    2020-08-08

最新评论