ホームページ > ウェブフロントエンド > jsチュートリアル > Node.js access_token は WeChat アクセスと更新の例を実装します

Node.js access_token は WeChat アクセスと更新の例を実装します

小云云
リリース: 2018-01-27 14:46:01
オリジナル
2034 人が閲覧しました

この記事では主にNode.jsのWeChatのaccess_token( jsapi_ticket )のアクセスとリフレッシュの例を紹介していますので、興味のある方はぜひ参考にしてみてください。

access_token

WeChat ドキュメントには、通常の access_token と Web 認証 access_token の 2 つの access_token があります。具体的な違いについては、 https://mp.weixin.qq.com/wiki?t=resource/res_main&id=mp1421140842 を参照してください

以下に記載されている access_token は、すべて通常の access_token です

1。 access_token をリクエストするには? WeChat パブリック プラットフォームの技術ドキュメント

GET リクエスト: https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid=APPID&secret=APPSECRET

通常の戻り値: {"access_token" :" ACCESS_TOKEN","expires_in":7200}

エラー戻り値: {"errcode":40013,"errmsg":"invalid appid"}

2 したがって、access_token を取得するコードは次のとおりです。

const request = require('request') // 请安装第三方包 request

request.get({
  uri: 'https://api.weixin.qq.com/cgi-bin/token',
  json: true,
  qs: {
   grant_type: 'client_credential',
   appid: APPID, // APPID请换成你的 appid
   secret: APPSECRET // APPSECRET请换成你的 appsecret
  }
 }, (err, res, body) => {
  if (err) {
   console.log(err)
   return
  }
  console.log(body)
  if (body.errcode) {
   // 返回错误时的处理
   return
  }
})
ログイン後にコピー

3 .guard_dog はデータの永続性を実装し、定期的な更新

guard_dog は .dog ファイルを生成します。各ファイルは KEY


const guard_dog = require('guard_dog') // 请安装第三方包 guard_dog

guard_dog.init(KEY, (handler) => { // KEY是guard_dog存取数据的键名
 // 拿到数据后调用 handler
 handler(DATA, EXPIREDS_IN) // DATA是要持久化的数据,EXPIREDS_IN是数据的有效时间,单位是秒
}, DIR) // DIR是 .dog 文件的存放目录,这个参数可以不传
ログイン後にコピー

4 に対応します。 want

const request = require('request')
const guard_dog = require('guard_dog')

guard_dog.init('ACCESS_TOKEN', (handler) => {
 request.get({
  uri: 'https://api.weixin.qq.com/cgi-bin/token',
  json: true,
  qs: {
   grant_type: 'client_credential',
   appid: APPID, // APPID请换成你的 appid
   secret: APPSECRET // APPSECRET请换成你的 appsecret
  }
 }, (err, res, body) => {
  if (err) {
   console.log(err)
   return
  }
  console.log(body)
  if (body.errcode) {
   return
  }
  handler(body.access_token, body.expires_in)
 })
}) // 如有需要指定目录,可以再给 guard_dog.init 多传个参数
ログイン後にコピー

5.guard_dog がこのキーを初期化すると、すべての有効な値が取得されます。 Guard_dog が値を取得するためのコードは次のとおりです:

guard_dog.get('ACCESS_TOKEN', (data) => { // 上面初始化时用的键名为'ACCESS_TOKEN',所以这里取值也要用这个键名
 // 在这里拿到的 data 就是 access_token 了
})
ログイン後にコピー

6. より便利に使用したい場合は、それをモジュール

access_token.js

const request = require('request')
const guard_dog = require('guard_dog')
// 加载这个模块的时候给 ACCESS_TOKEN 这个键名初始化
guard_dog.init('ACCESS_TOKEN', (handler) => {
 request.get({
  uri: 'https://api.weixin.qq.com/cgi-bin/token',
  json: true,
  qs: {
   grant_type: 'client_credential',
   appid: APPID, // APPID请换成你的 appid
   secret: APPSECRET // APPSECRET请换成你的 appsecret
  }
 }, (err, res, body) => {
  if (err) {
   console.log(err)
   return
  }
  console.log(body)
  if (body.errcode) {
   return
  }
  handler(body.access_token, body.expires_in)
 })
}) 
// 只要向外暴露一个获取值的方法就可以了
module.exports = function (callback) {
 guard_dog.get('ACCESS_TOKEN', callback)
}
ログイン後にコピー

にカプセル化することができます。

const access_token = require('./access_token') // 这里把这个模块与 access_token 模块当成在同一目录下来作为例子。
access_token((data) => {
 // 这个 data 就是 access_token
})
ログイン後にコピー

jsapi_ticket

jsapi_ticket 公式ドキュメントの説明


jsapi_ticket の処理も上記の例で詳しく説明されているので、コードを以下に直接貼り付けます。注: jsapi_ticket の取得は access_token に依存する必要があり、次のコードは上記の access_token.js に直接依存します)

jsapi_ticket.js

const request = require('request')
const guard_dog = require('guard_dog')
const access_token = require('./access_token')

guard_dog.init('JSAPI_TICKET', (handler) => {
 access_token((access_token) => {
  request.get({
   uri: 'https://api.weixin.qq.com/cgi-bin/ticket/getticket',
   json: true,
   qs: {
    access_token: access_token,
    type: 'jsapi'
   }
  }, (err, res, body) => {
   if (err) {
    console.log(err)
    return
   }
   console.log(body)
   if (body.errcode) {
    return
   }
   handler(body.ticket, body.expires_in)
  })
 })
})

module.exports = function (callback) {
 guard_dog.get('JSAPI_TICKET', callback)
}
ログイン後にコピー

使用:


const jsapi_ticket = require('./jsapi_ticket')
jsapi_ticket((data) => {
 // 这个 data 就是 jsapi_ticket
})
ログイン後にコピー

関連推奨事項:


phpツリー構造データアクセス例開発プロセス分析

解決策PHPアクセスmysql 4.1文字化け問題

PHPはテキストファイルを暗号化し、特定のページへのアクセスを制限する効果を実装します_phpの例

以上がNode.js access_token は WeChat アクセスと更新の例を実装しますの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

関連ラベル:
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
最新の問題
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート