微信JS-SDK使用步骤:
1.引入文件:<script type="text/javascript" src="http://res.wx.qq.com/open/js/jweixin-1.0.0.js"></script>
2.授权,通过config接口注入权限验证配置
所有需要使用JS-SDK的页面,必须先注入配置信息,否则将无法调用(同一个url仅需调用一次,对于变化url的SPA的web app可以在每次url变化时进行调用,目前android微信客户端不支持pushState的H5新特性,用pushState来实现web app 的页面会导致签名失败,android6.2后可用)。
wx.config({
debug: true, // 开启调试模式,调用的所有api的返回值会在客户端alert出来,若要查看传入的参数,可以在pc端打开,参数信息会通过log打出,仅在pc端时才会打印。
appId: '', // 必填,公众号的唯一标识
timestamp: , // 必填,生成签名的时间戳
nonceStr: '', // 必填,生成签名的随机串
signature: '',// 必填,签名,见附录1
jsApiList: [] // 必填,需要使用的JS接口列表,所有JS接口列表见附录2
});
3.通过ready接口处理成功验证
wx.ready(function(){
// config信息验证后会执行ready方法,所有接口调用都必须在config接口获得结果之后,config是一个客户端的异步操作,所以如果需要在页面加载时就调用相关接口,则须把相关接口放在ready函数中调用来确保正确执行。对于用户触发时才调用的接口,则可以直接调用,不需要放在ready函数中。
});
4.通过error接口处理失败验证
wx.error(function(res){
// config信息验证失败会执行error函数,如签名过期导致验证失败,具体错误信息可以打开config的debug模式查看,也可以在返回的res参数中查看,对于SPA可以在这里更新签名。
});
5.微信支付接口
wx.chooseWXPay({
timestamp: 0, // 支付签名时间戳,注意微信jssdk中的所有使用timestamp字段均为小写。但最新版的支付后台生成签名使用的timeStamp字段名需大写其中的S字符
nonceStr: '', // 支付签名随机串,不长于 32 位
package: '', // 统一支付接口返回的prepay_id参数值,提交格式如:prepay_id=***)
signType: '', // 签名方式,默认为'SHA1',使用新版支付需传入'MD5'
paySign: '', // 支付签名
success: function (res) {
// 拉起微信,支付成功后的回调函数(注意:此处微信已经支付成功,但是自己的服务器还没有收到来自微信服务器推送支付成功的消息,要等到微信服务器返回支付成功的信息到我们自己的服务器后,才知道支付真的成功了。)
//因此要在这写一个定时器,定时到服务器请求:id为的订单是否支付成功
timeJob = window.setInterval("$.getCommodityOrderInfo()",2000);
//真正成功后,再window.clearInterval(timeJob);
}
});
备注:prepay_id通过微信支付统一下单接口拿到,paySign采用统一的微信支付签名方法生成,注意这里appid与config中传入的一致,最后签名的参数有:appid,timeStamp,nonceStr,package,signType。
chooseWXPay:fail
订阅号要通过认证才可以支付,订阅号分享的文章,Android支付会失败。可以通过二维码的方式支付。
**粗体** _斜体_ [链接](http://example.com) `代码` - 列表 > 引用
。你还可以使用@
来通知其他用户。