1.0啟用開發者模式
①填寫伺服器設定
啟用開發模式需要先成為開發者,而且編輯模式與開發模式只能選擇一個(進入微信公眾平台=>開發=>基本配置)就可以看到以下的介面:
## 點選修改配置,會出現以下介面: 填寫伺服器位址(URL)、Token和EncodingAESKey,其中URL是開發者用來接收微信訊息和事件的介面URL。 Token可由開發者可任意填寫,用作生成簽章(此Token會和介面URL中所包含的Token進行比對,從而驗證安全性)。 EncodingAESKey由開發者手動填寫或隨機生成,將用作訊息體加解密金鑰。 同時,開發者可選擇訊息加上解密方式:明文模式、相容模式和安全模式。模式的選擇與伺服器配置在提交後都會立即生效,請開發者謹慎填寫及選擇。加解密方式的預設狀態為明文模式,選擇相容模式與安全模式需事先配置相關加解密程式碼,詳情請參考訊息本體簽章及加解密部分的文件(微信公眾號訊息加解密開發文件)。 ②驗證伺服器位址的有效性 開發者提交資訊後,微信伺服器將發送GET請求到填寫的伺服器位址URL上,GET請求攜帶四個參數。 #開發者透過檢驗signature對請求進行校驗(下面有校驗方式)。若確認此GET請求來自微信伺服器,請原樣回傳echostr參數內容,則存取生效,成為開發者成功,否則存取失敗(注意:微信伺服器只支援80埠)。 使用GET請求帶上以上參數請求伺服器,具體實現代碼:public void InterfaceTest() { string token = "配置时填写的token"; string echoString = HttpContext.Current.Request.QueryString["echoStr"]; string signature = HttpContext.Current.Request.QueryString["signature"]; string timestamp = HttpContext.Current.Request.QueryString["timestamp"]; string nonce = HttpContext.Current.Request.QueryString["nonce"]; if (!string.IsNullOrEmpty(echoString)) { HttpContext.Current.Response.Write(echoString); HttpContext.Current.Response.End(); } }
#