DDR爱好者之家 Design By 杰米
背景
客户要求可以直接识别标签二维码对某些仪器设备进行管理,类似于淘宝搜索框可以直接拍照搜索商品一样。前面已经做了一个网页调用摄像头识别二维码的功能,此功能有两个缺陷:
- 识别需要先拍照,不能直接识别
- 识别率低,尤其是拍照抖动,二维码内容稍微多一点或二维码小一点就识别不了。
以上两点相加就相当不好用了。
使用微信扫码
鉴于我们的系统已经集成到了微信公众号,所以准备调用微信扫码(只有在微信内打开的页面才能使用微信扫码)。
参照官方文档
绑定域名
打开公众号设置
选择功能设置
添加JS接口安全域名,注意你添加的域名目录下面上次图中微信指定的文件,如果文件没在根目录,域名需要填写到子目录
引入JS文件
使用vs2019创建默认的asp.net mvc项目
在index.cshtml页面中使用的页面引用js
<script src="/UploadFiles/2021-04-02/jweixin-1.1.0.js">前端主要代码
$(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"; 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"; 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 + "×tamp=" + 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"; var string1 = "jsapi_ticket=" + ticket + "&noncestr=" + nonceStr + "×tamp=" + 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
总结
以上所述是小编给大家介绍的网站搜索框使用微信扫码功能,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对网站的支持!
如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!
DDR爱好者之家 Design By 杰米
广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
DDR爱好者之家 Design By 杰米
暂无评论...
RTX 5090要首发 性能要翻倍!三星展示GDDR7显存
三星在GTC上展示了专为下一代游戏GPU设计的GDDR7内存。
首次推出的GDDR7内存模块密度为16GB,每个模块容量为2GB。其速度预设为32 Gbps(PAM3),但也可以降至28 Gbps,以提高产量和初始阶段的整体性能和成本效益。
据三星表示,GDDR7内存的能效将提高20%,同时工作电压仅为1.1V,低于标准的1.2V。通过采用更新的封装材料和优化的电路设计,使得在高速运行时的发热量降低,GDDR7的热阻比GDDR6降低了70%。
更新日志
2024年11月23日
2024年11月23日
- 凤飞飞《我们的主题曲》飞跃制作[正版原抓WAV+CUE]
- 刘嘉亮《亮情歌2》[WAV+CUE][1G]
- 红馆40·谭咏麟《歌者恋歌浓情30年演唱会》3CD[低速原抓WAV+CUE][1.8G]
- 刘纬武《睡眠宝宝竖琴童谣 吉卜力工作室 白噪音安抚》[320K/MP3][193.25MB]
- 【轻音乐】曼托凡尼乐团《精选辑》2CD.1998[FLAC+CUE整轨]
- 邝美云《心中有爱》1989年香港DMIJP版1MTO东芝首版[WAV+CUE]
- 群星《情叹-发烧女声DSD》天籁女声发烧碟[WAV+CUE]
- 刘纬武《睡眠宝宝竖琴童谣 吉卜力工作室 白噪音安抚》[FLAC/分轨][748.03MB]
- 理想混蛋《Origin Sessions》[320K/MP3][37.47MB]
- 公馆青少年《我其实一点都不酷》[320K/MP3][78.78MB]
- 群星《情叹-发烧男声DSD》最值得珍藏的完美男声[WAV+CUE]
- 群星《国韵飘香·贵妃醉酒HQCD黑胶王》2CD[WAV]
- 卫兰《DAUGHTER》【低速原抓WAV+CUE】
- 公馆青少年《我其实一点都不酷》[FLAC/分轨][398.22MB]
- ZWEI《迟暮的花 (Explicit)》[320K/MP3][57.16MB]