ホームページ > ウェブフロントエンド > jsチュートリアル > NodejsでWeChatの配送先住所を取得する方法

NodejsでWeChatの配送先住所を取得する方法

亚连
リリース: 2018-06-19 15:00:22
オリジナル
2234 人が閲覧しました

この記事では主にnodejsでWeChatの配信アドレスを取得する方法を詳しく紹介しますので、興味のある方は参考にしてください

この記事の例では、nodejsでWeChatの配信アドレスを取得する方法を共有します。具体的なコードは次のとおりです

WeChat の配送先アドレスを取得するための条件:

1. WeChat は配送先アドレス API を取得する必要があります。
2. 配送先アドレス機能に対応するドメイン名を設定します (ドメイン名の設定については、パブリック プラットフォーム Web サイト -> デベロッパー センター -> 設定項目 -> Web サービス -> Web ページにアクセスしてください)ユーザーの基本情報を取得するための権限 設定,)

router.js

var API = require('wechat-api'); 
var api = new API(config.wx_appid, config.wx_secret); 
 
var OAuth = require('wechat-oauth'); 
var client = new OAuth(config.wx_appid, config.wx_secret); 
 
/* auth */ 
app.get('/auth', function(req, res) { 
  var url = client.getAuthorizeURL('http://xxxxxxxxxx/getAddr','', 'snsapi_userinfo'); 
  res.redirect(url); 
}); 
 
 
app.get('/getAddr', function(req, res) { 
  var code = req.query.code; 
 
  client.getAccessToken(code, function (err, result) { 
    var accessToken = result.data.access_token; 
    var param = { 
      debug: false, 
      jsApiList: ['getLocation', 'onMenuShareAppMessage'], 
      url:"http://xxxxxxxxxx"+req._parsedUrl.href  //这个URL是你要拉起收货地址的实际URL 
    }; 
    api.getJsConfig(param, function(err,addrConfig){ 
      console.log('addrConfig = ',addrConfig); 
      var stra = "accesstoken="+accessToken+"&appid="+config.wx_appid+"&noncestr="+addrConfig.nonceStr+"×tamp="+addrConfig.timestamp+"&url="+param.url;//拼接string1 
      //console.log('stra = ',stra); 
      /* 
      common.sha1 
       
        // SHA1加密算法 
        exports.sha1 = function(str) { 
          var md5sum = crypto.createHash('sha1'); 
          md5sum.update(str); 
          str = md5sum.digest('hex'); 
          console.log(str) 
          return str; 
        } 
      */ 
      var strb = common.sha1(stra); 
      addrConfig.addrSign = strb; 
      addrConfig.stra = stra; 
      //console.log('strb = ',strb); 
          res.render('addr', { 
            addr: addrConfig, 
          }); 
    }); 
  }); 
});
ログイン後にコピー

addr.ejs

<!doctype html> 
<html> 
<head> 
<meta charset="UTF-8"> 
<meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1, user-scalable=no"> 
<meta name="apple-mobile-web-app-capable" content="yes">  
<meta name="apple-mobile-web-app-status-bar-style" content="black">  
<meta content="telephone=no" name="format-detection"> 
<title>demo</title> 
 
 
</head> 
 
<body> 
<pre class="brush:php;toolbar:false"> 
<%= addr.stra %> 
  WeixinJSBridge.invoke(&#39;editAddress&#39;, {  
    "appId": &#39;<%= addr.appId %>&#39;, 
    "scope": "jsapi_address", 
    "signType": "sha1", 
    "addrSign": &#39;<%= addr.addrSign %>&#39;, 
    "timeStamp": &#39;<%= addr.timestamp %>&#39;, 
    "nonceStr": &#39;<%= addr.nonceStr %>&#39;, 
  }, 
  
获取微信收货地址
ログイン後にコピー

以上は、今後皆さんのお役に立てれば幸いです。

関連記事:

vux を vue.js に統合してプルアップ読み込みとプルダウン更新を実装する方法

webpack の vue プロジェクト リソース ファイルに関する 404 問題の報告 (詳細なチュートリアル)

使用webpack+vue2 プロジェクトのビルド

以上がNodejsでWeChatの配送先住所を取得する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

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