此步骤就是调用后台接口获取配置,进行注册,同时可调用微信的分享接口进行注册,后续即可发起微信分享功能 。
- Node生成jssdk配置
- 获取全局access_token(非网页token)
- 获取jsapi_ticket
- 生成noncestr(随机数)
- 生成timestamp(时间戳)
- 签名(noncestr+jsapi_ticket+timestamp+url)
生成sdk配置信息流程就是这样,我这儿不再提供所有代码,只贴一下签名代码 。
let params = { noncestr:util.createNonceStr(), jsapi_ticket: data.ticket, timestamp:util.createTimeStamp(), url}let str = util.raw(params);let sign = createHash('sha1').update(str).digest('hex');res.json(util.handleSuc({ appId: config.appId, // 必填,公众号的唯一标识 timestamp: params.timestamp, // 必填,生成签名的时间戳 nonceStr: params.noncestr, // 必填,生成签名的随机串 signature: sign,// 必填,签名 jsApiList: [ 'updateAppMessageShareData', 'updateTimelineShareData', 'onMenuShareTimeline', 'onMenuShareAppMessage', 'onMenuShareQQ', 'onMenuShareQZone', 'chooseWXPay' ] // 必填,需要使用的JS接口列表}))到此,第一阶段就结束了,前端已经可以做分享、授权等功能了 。
- 调用支付钱包接口
this.$axios.get(API.payWallet,{ params:{ money } }).then((response)=>{ let result = response.data; if(result && result.code == 0){ // 通过微信的JS-API,拉起微信支付 let res = result.data; wx.chooseWXPay({ timestamp: res.timestamp, // 支付签名时间戳,注意微信jssdk中的所有使用timestamp字段均为小写 。但最新版的支付后台生成签名使用的timeStamp字段名需大写其中的S字符 nonceStr: res.nonceStr, // 支付签名随机串,不长于 32 位 package: res.package, // 统一支付接口返回的prepay_id参数值,提交格式如:prepay_id=***) signType: res.signType, // 签名方式,默认为'SHA1',使用新版支付需传入'MD5' paySign: res.paySign, // 支付签名 success: function (res) { // 成功 }, cancel:function(){ // 取消 }, fail:function(res){ // 失败 } }); } }) }调用钱包接口获取支付配置,拉起微信支付即可
- Node后台钱包接口
// 微信支付router.get('/pay/payWallet',function(req,res){ let openId = req.cookies.openId;//用户的openid let appId = config.appId;//应用的ID let attach = "微信支付课程体验";//附加数据 let body = "欢迎学习慕课首门支付专项课程";//支付主体内容 let total_fee = req.query.money;//支付总金额 // 支付成功后,会向此接口推送成功消息通知 let notify_url = "http://m.51purse.com/api/wechat/pay/callback" // 服务器IP let ip = "XX.XX.XX.XX"; // 封装的下单支付接口 wxpay.order(appId, attach, body, openId, total_fee, notify_url, ip).then((result) => { res.json(util.handleSuc(result)); }).catch((result) => { res.json(util.handleFail(result.toString())) });});
推荐阅读
-
-
人民日报客户端|美国新冠病毒感染病例超273万 新增超5.4万例
-
「娱乐分享君」我就帮她又拉了上去,搞笑GIF:我想她可能不喜欢我帮她拉上
-
气功大师街头用带电气功治病|魔术把戏?气功大师街头用带电气功治病:治完3年不感冒5年不咳嗽
-
-
『单身,诞生贵族,单身族,脱单,恋爱』小心六种心理 让女人无法摆脱单身
-
-
人尽未离|欧阳娜娜白西装搭金属框眼镜优雅知性,现身机场遭粉丝围堵人气旺
-
印度|印度男子自称医生宣扬牛粪和牛尿好处:现场边讲边吃
-
北青网综合|援鄂医疗队员国庆中秋重返武汉:从此武汉是故乡
-
-
-
-
-
俊男美女|历史上两位皇后同姓甄氏美女,她们的命运也非常相似
-
-
一天能赚1000块钱的游戏下载 什么游戏一天赚1000块
-
央视新闻客户端|江苏派出21人检验医疗队支援新疆新冠肺炎筛查核酸检测工作
-
-