溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

ASP.net?Core微信平臺(tái)開發(fā)怎么配置Token

發(fā)布時(shí)間:2022-04-29 15:47:33 來源:億速云 閱讀:151 作者:iii 欄目:開發(fā)技術(shù)

今天小編給大家分享一下ASP.net Core微信平臺(tái)開發(fā)怎么配置Token的相關(guān)知識(shí)點(diǎn),內(nèi)容詳細(xì),邏輯清晰,相信大部分人都還太了解這方面的知識(shí),所以分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后有所收獲,下面我們一起來了解一下吧。

首先登錄開發(fā)者平臺(tái),點(diǎn)擊開發(fā)者工具---》公眾平臺(tái)測(cè)試賬號(hào)

ASP.net?Core微信平臺(tái)開發(fā)怎么配置Token

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

ASP.net?Core微信平臺(tái)開發(fā)怎么配置Token

先創(chuàng)建一個(gè)配置實(shí)體

 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,與微信公共平臺(tái)上的Token保持一致
        /// </summary>
 private const string Token = "StupidMe";
   public void Valid(WeChatRequestModel model)
        {
            //獲取請(qǐng)求來的 echostr 參數(shù)
            string echoStr = model.echostr;
            //通過驗(yàn)證,出于安全考慮。(也可以跳過)
            if (CheckSignature(model))
            {
                if (!string.IsNullOrEmpty(echoStr))
                {
                    //將隨機(jī)生成的 echostr 參數(shù) 原樣輸出
                    Response.WriteAsync(echoStr);
                    //截止輸出流
                    //Response.end();
                }
            }
        }

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

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

 因?yàn)?,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é)議。

但是因?yàn)樯暾?qǐng)域名、服務(wù)器什么的麻煩,所以我就把自己電腦的防火墻關(guān)了,把項(xiàng)目發(fā)布到本機(jī)的IIS。然后在花生殼買了個(gè)域名,把自己的項(xiàng)目配上去就可以了(花了我18塊,心疼)。

ASP.net?Core微信平臺(tái)開發(fā)怎么配置Token

ASP.net?Core微信平臺(tái)開發(fā)怎么配置Token

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

(或許一開始會(huì)失敗,因?yàn)轵?yàn)證比較慢,點(diǎn)多幾次就成功了)

ASP.net?Core微信平臺(tái)開發(fā)怎么配置Token

以上就是“ASP.net Core微信平臺(tái)開發(fā)怎么配置Token”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家閱讀完這篇文章都有很大的收獲,小編每天都會(huì)為大家更新不同的知識(shí),如果還想學(xué)習(xí)更多的知識(shí),請(qǐng)關(guān)注億速云行業(yè)資訊頻道。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI