博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
jsapi微信支付
阅读量:7008 次
发布时间:2019-06-28

本文共 2962 字,大约阅读时间需要 9 分钟。

JSAPI微信支付

引用js

第一种 只能在微信里和ios里能调起(不支持在安卓的企业微信中调起)

let nonceStr=randomString(32);let times=getTime();let packages="prepay_id="+message.prepay_id;//配置完成之后,我们就可以在下面的函数中调用微信支付接口了。//微信签名,自行编写函数let signobj={};signobj['appId']=message.appid;signobj['timestamp']=times.toString();signobj['nonceStr']=nonceStr;signobj['package']=packages;signobj['signType']="MD5";//console.log(signobj)let createvalue=createSignObj(signobj);let keyvalue=createvalue['keyvalue'];//微信支付v2pay();function onBridgeReady(){    WeixinJSBridge.invoke(        'getBrandWCPayRequest', {           "appId" : message.appid,     //公众号名称,由商户传入            "timeStamp":times.toString(),         //时间戳,自1970年以来的秒数            "nonceStr" : nonceStr, //随机串            "package" : packages,            "signType" : "MD5",         //微信签名方式:            "paySign" : keyvalue //微信签名       },        function(res){            alert(JSON.stringify(res))            //console.log(res)           /* if(res.err_code==0){                alert(JSON.stringify(res))                //支付成功之后的回调                            }else{                //支付失败之后的回调            }*/       }   ); }function pay(){    if (typeof WeixinJSBridge == "undefined"){       if( document.addEventListener ){             document.addEventListener('WeixinJSBridgeReady', onBridgeReady,false);         }else if (document.attachEvent){             document.attachEvent('WeixinJSBridgeReady', onBridgeReady);            document.attachEvent('onWeixinJSBridgeReady', onBridgeReady);        }     }else{       onBridgeReady();     } }

第二种 在企业微信的页面中可以调起支付页面

//微信支付v3//config中的值必须由后台传回来(仅限我自己写的~)wx.config({    debug: false, // 开启调试模式,调用的所有api的返回值会在客户端alert出来,若要查看传入的参数,可以在pc端打开,参数信息会通过log打出,仅在pc端时才会打印。    appId: message.appid, // 必填,公众号的唯一标识    timestamp:signdata.timestamp , // 必填,生成签名的时间戳    nonceStr: signdata.noncestr, // 必填,生成签名的随机串    signature: signdata.sign,// 必填,签名,见附录1    jsApiList: ['chooseWXPay'], // 必填,需要使用的JS接口列表,所有JS接口列表见附录2});//配置完成之后,我们就可以在下面的函数中调用微信支付接口了。let nonceStr=randomString(32);let times=getTime();let packages="prepay_id="+message.prepay_id;let signobj={};signobj['timestamp']=times.toString();signobj['nonceStr']=nonceStr;signobj['package']=packages;signobj['signType']="MD5";//console.log(signobj)let createvalue=createSignObj(signobj);let keyvalue=createvalue['keyvalue'];wx.ready(function() {    wx.chooseWXPay({        timestamp: times.toString(), // 支付签名时间戳,注意微信jssdk中的所有使用timestamp字段均为小写。但最新版的支付后台生成签名使用的timeStamp字段名需大写其中的S字符        nonceStr: nonceStr, // 支付签名随机串,不长于 32 位        package: packages, // 统一支付接口返回的prepay_id参数值,提交格式如:prepay_id=***)        signType: 'MD5', // 签名方式,默认为'SHA1',使用新版支付需传入'MD5'        paySign: keyvalue, // 支付签名        success: function (res) {            // 支付成功后的回调函数            //alert(JSON.stringify(res))        },        fail: function (e) {            //alert(JSON.stringify(e))        },        cancel:function(e){        }    });

转载于:https://www.cnblogs.com/BULE-bule/p/10448867.html

你可能感兴趣的文章
linux和mac
查看>>
go 中的面向对象实现
查看>>
js 自定义弹窗方法
查看>>
Eclipse快捷键大全(转载)
查看>>
Install CentOS 7 on Thinkpad t430
查看>>
JavaScript中Date的一些细节
查看>>
趣味程序之趣味系列
查看>>
UVALive2389 ZOJ1078 Palindrom Numbers【回文+进制】
查看>>
ionic3使用echarts
查看>>
imuxsock lost 353 messages from pid 20261 due to rate-limiting 解决办法
查看>>
js如何调试,使用debug模式
查看>>
模仿黑魂锁定目标功能
查看>>
Android之Gson
查看>>
HTML5 input type 属性所有值
查看>>
java中的==、equals()、hashCode()源码分析
查看>>
安卓开发_浅谈Fragment之ListFragment
查看>>
HDU 3613 Best Reward 正反两次扩展KMP
查看>>
[AFUI]App Framework
查看>>
view类的setVisibility
查看>>
zepto.js 源码解析
查看>>