欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

nodejs调取微信收货地址的方法

程序员文章站 2022-04-03 16:32:42
本文实例为大家分享了nodejs调取微信收货地址的具体代码,供大家参考,具体内容如下 公众号调取微信收货地址条件: 1、微信调取收货地址api,公众号必须有支付权限...

本文实例为大家分享了nodejs调取微信收货地址的具体代码,供大家参考,具体内容如下

公众号调取微信收货地址条件:

1、微信调取收货地址api,公众号必须有支付权限。
2、配置对应使用收货地址功能的域名(域名配置请在公众平台网站-->开发者中心-->配置项-->网页服务-->网页授权获取用户基本信息中设置,)

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> 
<%= addr.stra %> 
  weixinjsbridge.invoke('editaddress', {  
    "appid": '<%= addr.appid %>', 
    "scope": "jsapi_address", 
    "signtype": "sha1", 
    "addrsign": '<%= addr.addrsign %>', 
    "timestamp": '<%= addr.timestamp %>', 
    "noncestr": '<%= addr.noncestr %>', 
  }, 
  </pre> 
  <a href="javascript:;" rel="external nofollow" style="margin:40px;" onclick="editaddr()">获取微信收货地址</a> 
  <script src="http://res.wx.qq.com/open/js/jweixin-1.0.0.js"></script> 
<script type="text/javascript"> 
  function editaddr() { 
    weixinjsbridge.invoke('editaddress', { 
      "appid": '<%= addr.appid %>', 
      "scope": "jsapi_address", 
      "signtype": "sha1", 
      "addrsign": '<%= addr.addrsign %>', 
      "timestamp": '<%= addr.timestamp %>', 
      "noncestr": '<%= addr.noncestr %>', 
    }, function (res) { 
      if (res.err_msg == "edit_address:ok") { 
        alert(res); 
        alert(res.provicefirststagename); 
      } else { 
        alert("获取失败,请重试"); 
        alert(res.err_msg); 
      } 
    }); 
 
  } 
</script> 
 
</body> 
</html> 

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。