婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > 網(wǎng)站搜索框使用微信掃碼功能

網(wǎng)站搜索框使用微信掃碼功能

熱門標(biāo)簽:高德地圖標(biāo)注公司位置需要錢嗎 怎么去掉地圖標(biāo)注文字 合肥阿里辦理400電話號 廊坊地圖標(biāo)注申請入口 地圖標(biāo)注資源分享注冊 襄陽外呼增值業(yè)務(wù)線路解決方案 北京外呼系統(tǒng)咨詢電話 海南人工外呼系統(tǒng)哪家好 慶陽外呼系統(tǒng)定制開發(fā)

背景

客戶要求可以直接識別標(biāo)簽二維碼對某些儀器設(shè)備進行管理,類似于淘寶搜索框可以直接拍照搜索商品一樣。前面已經(jīng)做了一個網(wǎng)頁調(diào)用攝像頭識別二維碼的功能,此功能有兩個缺陷:

  • 識別需要先拍照,不能直接識別
  • 識別率低,尤其是拍照抖動,二維碼內(nèi)容稍微多一點或二維碼小一點就識別不了。

以上兩點相加就相當(dāng)不好用了。

使用微信掃碼

鑒于我們的系統(tǒng)已經(jīng)集成到了微信公眾號,所以準(zhǔn)備調(diào)用微信掃碼(只有在微信內(nèi)打開的頁面才能使用微信掃碼)。
參照官方文檔

綁定域名

打開公眾號設(shè)置



選擇功能設(shè)置



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


引入JS文件

使用vs2019創(chuàng)建默認(rèn)的asp.net mvc項目

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

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

前端主要代碼

$(function () {
  /**
   * 判斷是否微信內(nèi)部打開頁面
   * */
  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;
    }
  }
  /**
   * 只有微信內(nèi)部頁面打開才能用
   * */
  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, // 開啟調(diào)試模式,調(diào)用的所有api的返回值會在客戶端alert出來,若要查看傳入的參數(shù),可以在pc端打開,參數(shù)信息會通過log打出,僅在pc端時才會打印。
          appId: data.appId, // 必填,公眾號的唯一標(biāo)識
          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配置錯誤,會彈出窗口哪里錯誤,然后根據(jù)微信文檔查詢即可。
        });
        wx.ready(function () {
          wx.checkJsApi({
            jsApiList: ['scanQRCode'],
            success: function (res) {
              //掃描二維碼
              wx.scanQRCode({
                needResult: 1, // 默認(rèn)為0,掃描結(jié)果由微信處理,1則直接返回掃描結(jié)果,
                scanType: ["qrCode"], // 可以指定掃二維碼還是一維碼,默認(rèn)二者都有
                success: function (res) {
                  var result = res.resultStr; // 當(dāng)needResult 為 1 時,掃碼返回的結(jié)果
                  alert(result);//因為我這邊是掃描后有個鏈接,然后跳轉(zhuǎn)到該頁面
                },
                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 = "******";
  //為了調(diào)試方便我這里第一次把Token和Ticket獲取到之后就寫死了,應(yīng)該寫入緩存(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 Taskstring> GetTicketAsync()
  {

    var tokenUrl = $"https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credentialappid={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 Taskstring> 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

總結(jié)

以上所述是小編給大家介紹的網(wǎng)站搜索框使用微信掃碼功能,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
如果你覺得本文對你有幫助,歡迎轉(zhuǎn)載,煩請注明出處,謝謝!

您可能感興趣的文章:
  • jQuery實現(xiàn)的類似淘寶網(wǎng)站搜索框樣式代碼分享
  • java實現(xiàn)網(wǎng)站微信掃碼支付
  • php實現(xiàn)微信原生支付(掃碼支付)功能
  • 自定義PC微信掃碼登錄樣式寫法
  • 詳解JAVA后端實現(xiàn)統(tǒng)一掃碼支付:微信篇
  • php實現(xiàn)微信掃碼自動登陸與注冊功能
  • PC 端微信掃碼注冊和登錄實例
  • .NET微信開發(fā)之PC 端微信掃碼注冊和登錄功能實現(xiàn)
  • 分享微信掃碼支付開發(fā)遇到問題及解決方案-附Ecshop微信支付插件

標(biāo)簽:綿陽 哈密 鎮(zhèn)江 臺州 鶴崗 株洲 商丘 平頂山

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《網(wǎng)站搜索框使用微信掃碼功能》,本文關(guān)鍵詞  網(wǎng)站搜索,框,使用,微信,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《網(wǎng)站搜索框使用微信掃碼功能》相關(guān)的同類信息!
  • 本頁收集關(guān)于網(wǎng)站搜索框使用微信掃碼功能的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    久久久午夜精品| 国产欧美精品一区| 欧美日韩免费一区二区三区 | 亚洲精品国产a久久久久久| 欧美男同性恋视频网站| 91丨porny丨国产| 在线视频中文字幕一区二区| 视频在线观看国产精品| 一区在线中文字幕| 亚洲你懂的在线视频| 亚洲黄色小视频| 亚洲成人免费视频| 日韩av在线播放中文字幕| 精品综合免费视频观看| 成人国产精品免费观看视频| 97精品国产露脸对白| 欧美视频日韩视频在线观看| 91精品国产乱码| 国产精品网曝门| 成人av免费在线播放| 天天综合网 天天综合色| 国产精品99久久久久| 日韩一区二区三区视频在线 | 成人久久视频在线观看| 777奇米四色成人影色区| 中文字幕不卡在线| 国产精品77777| 精品久久久三级丝袜| 日精品一区二区三区| 欧美色网一区二区| 一区二区三区美女视频| 99国产精品久久久| 亚洲动漫第一页| 精品国产精品网麻豆系列| 精品动漫一区二区三区在线观看| 不卡一区二区在线| 国产精品1区2区| 精品1区2区3区| 欧美日韩高清一区二区不卡| 欧美精品一区二区三区很污很色的| 欧美一区二区女人| 国产日韩欧美精品综合| 国产精品久久久久久亚洲伦| 久久99精品一区二区三区三区| 国产一区二区三区日韩| 欧美丝袜自拍制服另类| 久久综合色8888| 亚洲国产日产av| av在线一区二区三区| 欧美精品久久99| 亚洲欧美综合色| 国内久久精品视频| 不卡视频在线看| 欧美www视频| 国模娜娜一区二区三区| 国产夫妻精品视频| 欧美日韩亚洲综合在线| 成人av影视在线观看| 91麻豆精品91久久久久久清纯| 亚洲少妇中出一区| 91久久人澡人人添人人爽欧美| 中文字幕二三区不卡| 日产欧产美韩系列久久99| 综合欧美一区二区三区| 狠狠色丁香久久婷婷综| 久久99久久精品欧美| 亚洲免费在线视频一区 二区| 一区二区在线观看免费视频播放| 风流少妇一区二区| 懂色av一区二区三区免费看| 精品亚洲免费视频| 亚洲va中文字幕| 欧美国产日本韩| 国产色一区二区| 欧美高清视频在线高清观看mv色露露十八 | 国产精品18久久久| 亚洲天堂中文字幕| 亚洲欧洲www| 亚洲一二三区视频在线观看| 自拍偷在线精品自拍偷无码专区| 亚洲超碰97人人做人人爱| 欧美色男人天堂| 国产一区999| 91精品国产91热久久久做人人| 免费观看日韩av| 亚洲欧美成aⅴ人在线观看| 7777精品久久久大香线蕉| 韩国三级在线一区| 国产精品精品国产色婷婷| 精品少妇一区二区三区日产乱码 | 亚洲欧美成人一区二区三区| 日韩一区二区三区高清免费看看| 成人动漫av在线| 国产一区二区三区久久悠悠色av| 亚洲成在人线在线播放| 一区二区三区四区中文字幕| 精品国产免费人成电影在线观看四季| 欧美性猛交xxxx乱大交退制版| 国产精品一区二区三区四区| 人禽交欧美网站| 首页国产丝袜综合| 日本亚洲一区二区| 日韩avvvv在线播放| 粉嫩av亚洲一区二区图片| 国产精品电影院| 亚洲欧美日韩综合aⅴ视频| 亚洲国产成人tv| 久久se精品一区精品二区| 国产成人综合在线观看| 99久久国产综合色|国产精品| 色狠狠综合天天综合综合| 欧美日韩在线播| 久久蜜桃av一区二区天堂| 欧美国产日产图区| 亚洲美女视频在线观看| 夜夜嗨av一区二区三区| 免费不卡在线视频| 亚洲一区二区精品久久av| 免费一级片91| 91网站在线播放| 日韩精品一区二区三区视频在线观看| 日韩免费高清视频| 成人欧美一区二区三区| 国产在线不卡一卡二卡三卡四卡| 日本不卡在线视频| 色女孩综合影院| 国产午夜精品久久久久久久 | 国产精品成人在线观看| 美女诱惑一区二区| 色94色欧美sute亚洲线路一久 | 一区二区三区四区亚洲| 国产精品综合网| 久久综合久久鬼色| 日本不卡视频在线观看| 51精品视频一区二区三区| 亚洲成人精品一区二区| 欧美日韩一区二区三区在线| 久久久综合激的五月天| 欧美精品自拍偷拍| 日韩免费观看2025年上映的电影| 麻豆国产一区二区| 国产精品国产三级国产aⅴ无密码 国产精品国产三级国产aⅴ原创 | 欧美色爱综合网| 国产成人高清视频| 亚洲第一主播视频| 国产精品久久久久久亚洲伦| 菠萝蜜视频在线观看一区| 亚洲色图欧美偷拍| 欧洲精品一区二区三区在线观看| 亚洲一区视频在线| 欧美一卡在线观看| 国产精品亚洲一区二区三区在线| 欧美精品一区男女天堂| 国产suv精品一区二区6| 亚洲国产wwwccc36天堂| 精品国产自在久精品国产| 国产精品1024| 一个色在线综合| 久久综合九色综合97_久久久| 不卡的av网站| 久久国产精品无码网站| 亚洲天堂精品视频| 777奇米成人网| 成人不卡免费av| 国产一区二区福利| 免费欧美高清视频| 亚洲一区二区三区美女| 亚洲欧美综合色| 国产欧美日产一区| 4438x亚洲最大成人网| 国产精品一二三| 亚洲第一激情av| 亚洲视频图片小说| 精品少妇一区二区三区在线播放| 91国在线观看| 成人高清免费观看| 国产精品一区二区黑丝 | 午夜精彩视频在线观看不卡| 中文字幕亚洲一区二区av在线| 欧美一区永久视频免费观看| 在线观看成人小视频| 色婷婷综合久久久久中文一区二区 | 日本一区二区三区电影| 久久一区二区三区国产精品| 欧美老人xxxx18| 欧美一区二区三区白人| 在线一区二区三区四区| 欧美人与z0zoxxxx视频| 欧美一区二区三区四区在线观看| 欧美日韩精品一区二区三区四区| 91麻豆国产福利在线观看| 欧美影院精品一区| 69久久99精品久久久久婷婷| 欧美精品一区二区三区在线 | 日韩精品一区二区三区蜜臀| 日韩精品一区二区三区在线观看| 日本一区二区三区在线观看| 一区二区三区四区不卡在线| 裸体歌舞表演一区二区| 国产成人日日夜夜|