サブスクリプションメッセージテンプレートを選択または作成する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)
この記事では、角を丸くするためのjsキャンバスの具体的なコードを参考までに紹介します。具体的な内容は...
この記事では、Mysql の自己結合クエリについて説明します。ご参考までに、詳細は以下の通りです。自...
キーボードで文字を入力すると、対応するプロセスにどのように送信されるのでしょうか? ps や who...
ターゲットzabbix フロントエンド監視の iostat コマンドでデータの 1 つを表示します。...
CentOS7 64でのMySQL5.6.40のインストール手順1) 以前にインストールしたMySQ...
目次1. データベースを理解する1.1 データベースとデータ構造の関係1.2 なぜデータベースが必要...
Win10 システムでの MySQL 8.0.20 のインストールと設定の超詳細なチュートリアルMy...
目次序文: 1. コンセプト2. モジュール化の利点3. 複数のスクリプトタグを導入した後の問題1....
この記事では、参考までに、シンプルなページカウントダウンを実装するためのJavaScriptの具体的...
概要データベースでは、ツリー ディレクトリと同様に、インデックスを使用してデータ検索を高速化します。...
目次成果を達成する実装コード最近、会社でelementUIを使い始めたため、開発の過程でテーブルのセ...
目次1. コンポーネント2. キープアライブ2.1 問題点2.2 キープアライブを使って解決する2....
序文: Jenkins のマスター スレーブ分散アーキテクチャは、主に、Jenkins に単一ポイン...
<br />このシリーズの最初のセクションでは、Web サイトのパフォーマンスを向上させ...
1. MySQL アーカイブ (解凍版) をダウンロードするURL: https://downloa...