微信小程序開發消息推送配置這一塊網上都是PHP居多,因爲本身在用egg.js,因此用egg.js寫了一套驗證方法。小程序
第一步:填寫服務器配置微信小程序
登陸微信小程序官網後,在小程序官網的「設置-消息服務器」頁面,管理員掃碼啓用消息服務,填寫服務器地址(URL)、Token 和 EncodingAESKey。安全
URL是開發者用來接收微信消息和事件的接口URL。 Token可由開發者能夠任意填寫,用做生成簽名(該Token會和接口URL中包含的Token進行比對,從而驗證安全性)。 EncodingAESKey由開發者手動填寫或隨機生成,將用做消息體加解密密鑰。服務器
同時,開發者可選擇消息加解密方式:明文模式、兼容模式和安全模式。能夠選擇消息數據格式:XML格式或JSON格式。加密方式的默認狀態是明文格式,而數據格式的默認狀態是XML格式。微信
模式的選擇與服務器配置在提交後都會當即生效,請開發者謹慎填寫及選擇。切換加密方式和數據格式須要提早配置好相關代碼,詳情請參考消息加解密說明。post
第二部:驗證消息來自微信服務端加密
開發者提交信息後,微信服務器將發送GET請求到填寫的服務器地址URL上,GET請求攜帶參數以下表所示:spa
參數 | 描述 |
---|---|
signature | 微信加密簽名,signature結合了開發者填寫的token參數和請求中的timestamp參數、nonce參數。 |
timestamp | 時間戳 |
nonce | 隨機數 |
echostr | 隨機字符串 |
開發者經過檢驗signature對請求進行校驗(下面有校驗方式)。若確認這次GET請求來自微信服務器,請原樣返回echostr參數內容,則接入生效,成爲開發者成功,不然接入失敗。加密/校驗流程以下: 一、將token、timestamp、nonce三個參數進行字典序排序 二、將三個參數字符串拼接成一個字符串進行sha1加密 三、開發者得到加密後的字符串可與signature對比,標識該請求來源於微信3d
要注意的是簽名驗證經過以後,要返回的echostr字段是字符串,而不是對象。若是返回寫的是 ctx.body = { echostr }就會顯示token驗證失敗。對象
第三步:依據接口文檔實現業務邏輯
驗證URL有效性成功後即接入生效,成爲開發者。至此用戶向小程序客服發送消息、或者進入會話等狀況時,開發者填寫的服務器配置URL將獲得微信服務器推送過來的消息和事件,開發者能夠依據自身業務邏輯進行響應。
此時的路徑和你填寫的URL一致,可是驗證的時候是get請求,此時發送消息是post請求。