日本免费高清视频-国产福利视频导航-黄色在线播放国产-天天操天天操天天操天天操|www.shdianci.com

學無先后,達者為師

網站首頁 編程語言 正文

ASP.net?Core微信平臺開發配置Token_實用技巧

作者:騙你學計算機 ? 更新時間: 2022-06-27 編程語言

如果先進行微信平臺開發,配置Token是第一步。否則往后所有的代碼都沒辦法在平臺上跑得動。

但是官方給的源碼是PHP的,ASP.net core 配置Token 的版本又少。研究怎么配置Token浪費了我超多時間。

首先登錄開發者平臺,點擊開發者工具---》公眾平臺測試賬號

然后就需要配置我們的接口信息了?

先創建一個配置實體

 public class WeChatRequestModel
    {
        public string signature { get; set; }
        public string timestamp { get; set; }
        public string nonce { get; set; }
        public string echostr { get; set; }
    }

然后我們只需要在HomeController控制器上有一段代碼就可以配置Token了

          /// <summary>
        /// 定義Token,與微信公共平臺上的Token保持一致
        /// </summary>
 private const string Token = "StupidMe";
   public void Valid(WeChatRequestModel model)
        {
            //獲取請求來的 echostr 參數
            string echoStr = model.echostr;
            //通過驗證,出于安全考慮。(也可以跳過)
            if (CheckSignature(model))
            {
                if (!string.IsNullOrEmpty(echoStr))
                {
                    //將隨機生成的 echostr 參數 原樣輸出
                    Response.WriteAsync(echoStr);
                    //截止輸出流
                    //Response.end();
                }
            }
        }

但是出于安全考慮,弄了一個CheckSignature(model),進行驗證(可以不用只是不安全)

/// <summary>
        /// 驗證簽名,檢驗是否是從微信服務器上發出的請求
        /// </summary>
        /// <param name="model">請求參數模型 Model</param>
        /// <returns>是否驗證通過</returns>
        private bool CheckSignature(WeChatRequestModel model)
        {
            string signature, timestamp, nonce, tempStr;
            //獲取請求來的參數
            signature = model.signature;
            timestamp = model.timestamp;
            nonce = model.nonce;
            //創建數組,將 Token, timestamp, nonce 三個參數加入數組
            string[] array = { Token, timestamp, nonce };
            //進行排序
            Array.Sort(array);
            //拼接為一個字符串
            tempStr = String.Join("", array);
            //對字符串進行 SHA1加密
            tempStr = Get_SHA1_Method2(tempStr);
            //判斷signature 是否正確
            if (tempStr.Equals(signature))
            {
                return true;
            }
            else
            {
                return false;
            }
        }

?因為,signature是經過SHA1加密的,所以我們也要,進行一些SHA1加密才可以進行比較

 public string Get_SHA1_Method2(string strSource)
        {
            string strResult = "";
            //Create 
            System.Security.Cryptography.SHA1 md5 = System.Security.Cryptography.SHA1.Create();
            //注意編碼UTF8、UTF7、Unicode等的選擇 
            byte[] bytResult = md5.ComputeHash(System.Text.Encoding.UTF8.GetBytes(strSource));
            //字節類型的數組轉換為字符串 
            for (int i = 0; i < bytResult.Length; i++)
            {
                //16進制轉換 
                strResult = strResult + bytResult[i].ToString("X");
            }
            return strResult.ToLower();
        }

在我們的ASP.net Core寫好代碼以后,我們就發布了。注意,微信要求必須是80端口,且HTTP協議。

但是因為申請域名、服務器什么的麻煩,所以我就把自己電腦的防火墻關了,把項目發布到本機的IIS。然后在花生殼買了個域名,把自己的項目配上去就可以了(花了我18塊,心疼)。

這樣只,我們最基礎的配置代碼就完成了,然后把我們的Valid接口配過去就成功啦!!!!

(或許一開始會失敗,因為驗證比較慢,點多幾次就成功了)

參考:https://www.jb51.net/article/246547.htm

原文鏈接:https://blog.csdn.net/wangwengrui40/article/details/86717833

欄目分類
最近更新