TNW-開(kāi)啟公眾號(hào)開(kāi)發(fā)者模式

TNW-開(kāi)啟公眾號(hào)開(kāi)發(fā)者模式

簡(jiǎn)介

TNW: TypeScript(The) + Node.js(Next) + WeChat 微信公眾號(hào)開(kāi)發(fā)腳手架,支持 http 模塊擴(kuò)展、支持任何 Node.js 的服務(wù)端框架(Express、NestJS 等)

安裝

NPM 依賴(lài)方式

1、下載

$ npm i tnw

2、Express 示例

3、Nest 示例

源碼方式

1、下載項(xiàng)目并安裝依賴(lài)

$ git clone https://github.com/Javen205/TNW.git 
或者 
$ git clone https://gitee.com/Javen205/TNW.git 
$ cd TNW
$ npm install 

2、編譯并運(yùn)行

$ npm run build 
$ npm run dev

3、完整示例

配置公眾號(hào)參考

  // 亦可以讀取配置文件
  let apiConfig = new ApiConfig("Javen", "wx614c453e0d1dcd12", "19a02e4927d346484fc70327970457f9");
  // 支持多公眾號(hào)
  ApiConfigKit.putApiConfig(apiConfig);
  // 開(kāi)啟開(kāi)發(fā)模式,方便調(diào)試
  ApiConfigKit.devMode = true;

特別說(shuō)明

  1. 支持多公眾號(hào)配置,如需要可以多實(shí)例化 ApiConfig 然后調(diào)用 ApiConfigKit.putApiConfig(apiConfig) 進(jìn)行設(shè)置。

  2. ApiConfig 參數(shù)說(shuō)明

    第一個(gè)參數(shù):令牌 Token 可以任意填寫(xiě)

    第二個(gè)參數(shù):開(kāi)發(fā)者ID appId

    第三個(gè)參數(shù):開(kāi)發(fā)者密碼 appScrect

    第四個(gè)參數(shù):是否開(kāi)啟加密 encryptMessage 默認(rèn)值為 false

    第五個(gè)參數(shù):消息加解密密鑰 encodingAesKey 非必須

  3. 設(shè)置多個(gè)公眾號(hào)配置時(shí)默認(rèn)使用第一個(gè) ApiConfig

  4. 切換公眾號(hào)配置可以調(diào)用 ApiConfigKit.setCurrentAppId(appId)

公眾號(hào)開(kāi)啟開(kāi)發(fā)者模式

TNW 中驗(yàn)證簽名的關(guān)鍵接口如下:

WeChat.checkSignature(signature, timestamp,nonce, echostr)

Express 示例如下:

app.get('/msg', (req: any, res: any) => {
    console.log('get query...', req.query);

    let appId: string = req.query.appId;
    if (appId) {
        ApiConfigKit.setCurrentAppId(appId);
    }

    let signature = req.query.signature,//微信加密簽名
        timestamp = req.query.timestamp,//時(shí)間戳
        nonce = req.query.nonce,//隨機(jī)數(shù)
        echostr = req.query.echostr;//隨機(jī)字符串
    res.send(WeChat.checkSignature(signature, timestamp,
        nonce, echostr));
});

Nest 示例如下:

@Get('/msg')
getMsg(@Req() request: Request, @Res() response: Response) {
  let appId: string = request.query.appId;
  if (appId) {
    ApiConfigKit.setCurrentAppId(appId);
  }

  let signature = request.query.signature,//微信加密簽名
      timestamp = request.query.timestamp,//時(shí)間戳
      nonce = request.query.nonce,//隨機(jī)數(shù)
      echostr = request.query.echostr;//隨機(jī)字符串
  response.send(WeChat.checkSignature(signature, timestamp,nonce, echostr));
}

特別說(shuō)明:

  1. 開(kāi)發(fā)者URL為:http/https://域名/msg 或者 http/https://域名/msg?appId=xxxxx
  2. 測(cè)試號(hào)的加密模式必須設(shè)置為 false (上文提到的 ApiConfig 第四個(gè)參數(shù))
  3. 正式號(hào)推薦開(kāi)啟加密模式并設(shè)置為 安全模式

本地端口映射工具

推薦使用 FRP 目前Github Start 已超越 2.2w。如有更好的工具歡迎推薦(留言區(qū)見(jiàn))

開(kāi)源推薦

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書(shū)系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容