此步骤就是调用后台接口获取配置,进行注册,同时可调用微信的分享接口进行注册,后续即可发起微信分享功能 。
- 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())) });});
推荐阅读
-
就是爱搞机|主打性价比的荣耀play系列发布新机!会是同级别中最便宜的一款?
-
-
鹰眼防务观察|土耳其运用更加出色,利比亚上空的无人机:“翼龙”常被己方击落
-
北京如果取消小客车摇号政策全面放开购买,交通会变怎么样
-
「育儿小手册」体验服蒙犽再次削弱,急速战靴攻速降低,王者荣耀3.21更新
-
-
美好,一直在身边【品牌社区】科技带来的便捷你知道有多少吗?
-
清朝|从这件事情就能看出,乾隆与雍正之间有多大区别!
-
爱集微APP|其他业务占比较小,紫光国微:目前以芯片设计业务为主
-
-
环球网|喀什:排除疏附县疫情与7月份乌鲁木齐疫情病毒的相关性
-
-
-
摄诗文史版|建都时间最长的是哪个?,中国历史上的七大古都
-
-
|美国刚刚表示:还想再借12.05万亿,中国大抛2500亿美债后
-
周冬雨@唐艺昕产女张若昀发红包,公布怀孕生产好消息比唐嫣罗晋大方坦诚
-
电脑报|CHERRY ∞ 2020线上发布会即将召开,直播抽奖
-
-