ASP.net?Core微信平臺(tái)開發(fā)配置Token
如果先進(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)文章
ASP.NET MVC使用ActionFilterAttribute實(shí)現(xiàn)權(quán)限限制的方法(附demo源碼下載)
這篇文章主要介紹了ASP.NET MVC使用ActionFilterAttribute實(shí)現(xiàn)權(quán)限限制的方法,結(jié)合實(shí)例形式分析了ASP.NET MVC使用ActionFilterAttribute過濾類實(shí)現(xiàn)權(quán)限限制的步驟與相關(guān)技巧,并附帶demo源碼供讀者下載,需要的朋友可以參考下2016-04-04ASP.NET中后臺(tái)注冊(cè)js腳本使用的方法對(duì)比
接下來(lái)為大家介紹下使用Page.ClientScript.RegisterClientScriptBlock 和Page.ClientScript.RegisterStartupScript:區(qū)別2013-04-04ASP.NET?Core項(xiàng)目中調(diào)用WebService的方法
這篇文章介紹了ASP.NET?Core項(xiàng)目中調(diào)用WebService的方法,文中通過示例代碼介紹的非常詳細(xì)。對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-03-03asp.net中javascript的引用(直接引入和間接引入)
Asp.net 中引入Javascript的方法有很多,個(gè)人認(rèn)為可以分為直接引入,和間接引入,下面是兩種具體的引用方法,感興趣的朋友可以參考下哈2013-06-06php基礎(chǔ)練習(xí)--簡(jiǎn)單驗(yàn)證碼實(shí)現(xiàn)
這篇文章主要介紹了php基礎(chǔ)練習(xí)--簡(jiǎn)單驗(yàn)證碼實(shí)現(xiàn),需要的朋友可以參考下2014-02-02.NET程序集引用COM組件MSScriptControl遇到問題的解決方法
這篇文章主要為大家詳細(xì)介紹了.NET程序集引用COM組件MSScriptControl遇到問題的解決方法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-01-01asp.net 分頁(yè)顯示數(shù)據(jù)表的數(shù)據(jù)的代碼
asp.net顯示第一頁(yè)、上一頁(yè)、下一頁(yè)和最后一頁(yè)的分頁(yè)顯示數(shù)據(jù)表的數(shù)據(jù)2010-03-03vb 中的MD5加密在asp.net中的實(shí)現(xiàn)
給定標(biāo)識(shí)哈希類型的密碼和字符串,該例程產(chǎn)生一個(gè)適合存儲(chǔ)在配置文件中的哈希密碼,感興趣的朋友可以參考下本文2013-04-04Asp.net中使用PageDataSource分頁(yè)實(shí)現(xiàn)代碼
這篇文章主要介紹asp.net中使用PageDataSource分頁(yè)的方法,需要的朋友可以參考下2013-04-04