サブスクリプションメッセージテンプレートを選択または作成するWeChat アプレットにログインし、「機能」->「メッセージの購読」を見つけます。公開テンプレート ライブラリから必要なテンプレートを選択できます。必要なものが見つからない場合は、自分で作成してレビューを待つこともできます。 テンプレートを選択して詳細を表示すると、テンプレート ID とプッシュ通知の送信に必要なフィールドが表示されます。 アプレットはサブスクリプションリクエストを送信します前の手順で取得したテンプレートIDが必要です // ミニプログラム<Text className='rights-buy' onClick={this.messageSubmit}> 入学願書</Text> // 決済申請メッセージを購読する messageSubmit = () => { 太郎.requestSubscribeMessage({ tmplIds: ['SuGMwqyYY9cocuP-LxfElcM3a7ITaF34lKNux6EaE9'], 成功: (res) => { // サーバー インターフェイスを呼び出して、データベースにサブスクリプション レコードを書き込みます // this.subscribeDeal() } }) } サーバーがプッシュを開始するプッシュには一般的に2つの種類がある
最初のケースでは、WeChat のプッシュ インターフェースを直接呼び出すだけです。 2 番目の状況は少し面倒です。時間指定のタスクを追加するか、関連するキュー ライブラリを使用して条件が満たされたときにトリガーすることができます。 注意事項
access_tokenを取得してキャッシュする 非同期getAccessToken() { const { appId、 appSecert、 host } = this.app.config.idolWxAConfig; 新しい Promise(async (resolve) => { を返します。 定数 currentTime = 新しい Date().getTime() const redisToken = this.app.redis.get('wxtoken').get('token') を待機 || '{access_token: "", expries_time: 0}' const accessTokenJson = JSON.parse(redisToken) accessTokenJson.access_token === '' || accessTokenJson.expries_time < currentTime の場合 { const res = this.ctx.curl(`${host}/cgi-bin/token?appid=${appId}&secret=${appSecert}&grant_type=client_credential`, { dataType: 'json' }) を待機します。 (res.data)の場合{ accessTokenJson.access_token = res.data.access_token accessTokenJson.expries_time = 新しい Date().getTime() + (parseInt(res.data.expires_in) - 200) * 1000 this.app.redis.get('wxtoken').set('token', JSON.stringify(accessTokenJson)) を待ちます。 accessTokenJson を解決します } } それ以外 { accessTokenJson を解決します } }) } WeChatにプッシュリクエストを送信する 非同期sendSubscribeMsg(openid) { リクエストデータ = { "touser": `${openid}`, "テンプレートID": "SuGMwqyYY9cocuP-LxfElcM3a7ITaF34lKNux6EaE9", "ページ": `/pages/certification/index`, "データ": { 「フレーズ2」: { "値": `承認済み` }, "もの3": { "value": `あなたの申請は審査され、承認されました` } } } 定数 { ホスト } = this.app.config.idolWxAConfig; // access_toekn を取得する const tokenJson = this.ctx.service.wx.getAccessToken() を待機します const res = this.ctx.curl(`${host}/cgi-bin/message/subscribe/send?access_token=${tokenJson.access_token} を待機します。 `、{ メソッド: 'POST'、 コンテンツタイプ: 'json', データ: リクエストデータ、 データ型: 'json' }); res.data.errmsg === 'ok'の場合{ console.log('========プッシュに成功しました========') //やるべきこと } それ以外 { console.log('========プッシュに失敗しました========') //やるべきこと } } Nodejs WeChat アプレット メッセージ プッシュの実装に関するこの記事はこれで終わりです。より関連性の高い Nodejs アプレット メッセージ プッシュ コンテンツについては、123WORDPRESS.COM で以前の記事を検索するか、次の関連記事を引き続き参照してください。今後も 123WORDPRESS.COM を応援していただければ幸いです。 以下もご興味があるかもしれません:
|
>>: MySQL 5.7.17 無料インストールバージョンの設定方法グラフィックチュートリアル (Windows10)
序文私たちのビジネスがまだ初期段階にあり、同時実行の度合いが比較的低い場合、数年間はデッドロックの問...
電話Amap API を呼び出す方法は? Amap が https://lbs.amap.com/a...
この記事のガイド: テーブル内のデータを削除するには、削除と切り捨ての 2 つの方法があります。TR...
この記事では、簡単なショッピングフォームを実装するためのJavaScriptの具体的なコードを参考ま...
目次1. TypeScriptが古いVueプロジェクトに導入されるVue+Typescript プロ...
仮想マシンを初めて使用する方や、仮想マシンに Linux をインストールしたばかりの方は、システムが...
MySql インデックスの詳細な紹介と正しい使用方法1. はじめに:インデックスはクエリ速度に重大な...
ReactRouterの実装ReactRouterはReactのコアコンポーネントです。主にReac...
解決策は次のとおりです。 1. コンテナを強制削除する docker rm -f ジェンキンス2. ...
目次1. SQL最適化の一般的な手順1. SQL実行計画の分析を説明する2. プロフィール分析を表示...
美しいコードは美しい Web サイトの基礎です。優れた CSS は、同様に優れた HTML の上にの...
NetEase Blog で HTML を使用する場合、テンプレートに直接コードを追加できることは...
zabbix を利用する上での最大のボトルネックはデータベースです。zabbix のデータストレージ...
目次序文最適化変数の抽出二次包装 el-tag コンポーネント使用要約する序文バックエンドシステムの...
Cudaがインストールされているかどうかを確認してくださいアナコンダプロンプトに入力nvcc -V...