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

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

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

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

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

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

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

先創(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)求來(lái)的 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)求來(lái)的參數(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)椋瑂ignature是經(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塊,心疼)。

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

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

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

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

相關(guān)文章

最新評(píng)論