欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

ASP.net?Core微信平臺開發(fā)配置Token

 更新時間:2022年04月29日 17:13:30   作者:騙你學(xué)計算機  
這篇文章主要為大家介紹了ASP.net?Core微信平臺開發(fā)配置Token有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪

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

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

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

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

先創(chuàng)建一個配置實體

 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 參數(shù)
            string echoStr = model.echostr;
            //通過驗證,出于安全考慮。(也可以跳過)
            if (CheckSignature(model))
            {
                if (!string.IsNullOrEmpty(echoStr))
                {
                    //將隨機生成的 echostr 參數(shù) 原樣輸出
                    Response.WriteAsync(echoStr);
                    //截止輸出流
                    //Response.end();
                }
            }
        }

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

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

 因為,signature是經(jīng)過SHA1加密的,所以我們也要,進(jìn)行一些SHA1加密才可以進(jìn)行比較

 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));
            //字節(jié)類型的數(shù)組轉(zhuǎn)換為字符串 
            for (int i = 0; i < bytResult.Length; i++)
            {
                //16進(jìn)制轉(zhuǎn)換 
                strResult = strResult + bytResult[i].ToString("X");
            }
            return strResult.ToLower();
        }

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

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

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

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

參考:http://www.dbjr.com.cn/article/246547.htm

以上就是ASP.net Core微信平臺開發(fā)配置Token的詳細(xì)內(nèi)容,更多關(guān)于ASP.net Core微信配置Token的資料請關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

最新評論