文章出處

ASP.NET MVC 接入微信公共平臺

  1. 申請微信公共賬號

    既然要接入微信公共平臺,微信公共號是必須的(當然如果只是測試的話也可以申請微信公共平臺接口測試賬號),來這里微信公共平臺 申請微信公共號(注:申請微信公共號不能用已綁定微信的郵箱),微信公共平臺有自己的官方文檔,官方文檔有不少資料,可以多看看,開發者模式默認是關閉的,需要配置并啟用,如下圖:

    URL即你的網站處理微信模塊,必須是HTTP://開頭的網站,筆者自己之前接入幾天一直失敗,最終發現是因為自己網站加密了用的是HTTPS,這個需要注意HTTPS網站是不可以的,Token是不會驗證成功的,Token是自定義的不少于3個字符,EncodingAESKey會在加密消息時用到。

  2. 編寫網站邏輯

    編寫微信接口測試代碼,創建控制器,在控制器中編寫代碼,編寫一個Action 方法用于微信服務器檢驗,Token是否配置成功或者接入成功。既然使用MVC,本人比較懶,懶得用Request.QueryStrings["echostr"] 這樣的方法來一個一個獲取參數,于是創建了一個Model,用來讓微信服務器請求時參數自動適配到Model的相應屬性,便于訪問,便于寫代碼,在微信公共平臺的官方文檔中可以看到用到的參數

    于是創建一個這樣的Model

    1  public class WeChatRequestModel
    2     {
    3         public string signature { get; set; }
    4         public string timestamp { get; set; }
    5         public string nonce { get; set; }
    6 
    7         public string echostr { get; set; }
    8     }
    View Model Code

     

    接著看官方文檔,接下來開始在控制器中編寫代碼,開始驗證

    根據校驗流程開始編寫代碼,也可參考官方給出PHP代碼編寫相應的 .NET 代碼

    下面給出我的示例代碼,在接入沒成功之前參考許多別人的代碼,不一定是最好的,你也可以參考一些別人的代碼(這里說明一下,驗證signature是否正確是從安全方面考慮的,你也可以將GET請求中的echostr參數直接輸出,建議還是驗證一下,畢竟安全更重要一些)

    用來讓微信服務器訪問的Action 方法代碼

  3. 配置微信公共平臺上的信息

    配置接入服務器,圖中的參數都必須配置,Token要與網站代碼中的Token保持一致,EncodingAESKey直接隨機生成就可以,當然自己寫也是可以的,只要你愿意,消息加解密方式,建議開發測試階段選擇明文模式以及兼容模式,正式上線使用后選擇安全模式。最后第一項也是最重要的一項,URL,再次強調必須是HTTP網站,HTTPS是驗證不成功的,如果是HTTPS能改成HTTP的話要改成HTTP,Url寫成剛才我們編寫的用于訪問的驗證的Action的Url地址,即要訪問這個控制器時請求的URL地址,如: http://www.example.com/Home/Valid/

     1  public class HomeController :Controller
     2      {
     3         /// <summary>
     4         /// 定義Token,與微信公共平臺上的Token保持一致
     5         /// </summary>
     6         private const string Token = "StupidMe";
     7 
     8          /// <summary>
     9          /// 驗證簽名,檢驗是否是從微信服務器上發出的請求
    10          /// </summary>
    11          /// <param name="model">請求參數模型 Model</param>
    12          /// <returns>是否驗證通過</returns>
    13          private bool CheckSignature(Model.FormatModel.WeChatRequestModel model)
    14          {
    15              string signature, timestamp, nonce, tempStr;
    16              //獲取請求來的參數
    17              signature = model.signature;
    18              timestamp = model.timestamp;
    19              nonce = model.nonce;
    20              //創建數組,將 Token, timestamp, nonce 三個參數加入數組
    21             string[] array = { Token, timestamp, nonce };
    22             //進行排序
    23              Array.Sort(array);
    24              //拼接為一個字符串
    25              tempStr = String.Join("", array);
    26              //對字符串進行 SHA1加密
    27              tempStr = FormsAuthentication.HashPasswordForStoringInConfigFile(tempStr, "SHA1").ToLower();
    28              //判斷signature 是否正確
    29              if (tempStr.Equals(signature))
    30             {
    31                  return true;
    32              }
    33              else
    34              {
    35                  return false;
    36              }
    37          }
    38 
    39  
    40          public void Valid(Model.FormatModel.WeChatRequestModel model)
    41          {
    42              //獲取請求來的 echostr 參數
    43              string echoStr = model.echostr;
    44             //通過驗證
    45              if (CheckSignature(model))
    46              {
    47                 if (!string.IsNullOrEmpty(echoStr))
    48                 {
    49                     //將隨機生成的 echostr 參數 原樣輸出
    50                      Response.Write(echoStr);
    51                      //截止輸出流
    52                      Response.End();
    53                  }
    54              }
    55          }
    56      }
    View Smaple Code

     

     

     

     

     

     

 


文章列表




Avast logo

Avast 防毒軟體已檢查此封電子郵件的病毒。
www.avast.com


arrow
arrow
    全站熱搜
    創作者介紹
    創作者 大師兄 的頭像
    大師兄

    IT工程師數位筆記本

    大師兄 發表在 痞客邦 留言(0) 人氣()