微信支付详解与取消支付回调

第一步:绑定域名
先登录微信公众平台进入“公众号设置”的“功能设置”里填写“JS接口安全域名”。如果你使用了支付类接口,请确保支付目录在该安全域名下,否则将无法完成支付。
备注:登录后可在“开发者中心”查看对应的接口权限。

第二步:引入js

在需要调用JS接口的页面引入如下JS文件:

步骤三:js调用

//通过ajax调用后台微信签名接口
wx.config({
    debug: true, //(测试完记得改为false) 开启调试模式,调用的所有api的返回值会在客户端alert出来,若要查看传入的参数,可以在pc端打开,参数信息会通过log打出,仅在pc端时才会打印。
    appId: '', // 必填,公众号的唯一标识
    timestamp: , // 必填,生成签名的时间戳
    nonceStr: '', // 必填,生成签名的随机串
    signature: '',// 必填,签名,见附录1
    jsApiList: ['chooseWXPay'] // 必填,需要使用的JS接口列表,所有JS接口列表见附录2
});
//配置成功后执行
wx.ready(function(){
	//点击支付后,调用(参数需要从后台获取)
	wx.chooseWXPay({
	    timestamp: 0, // 支付签名时间戳,注意微信jssdk中的所有使用timestamp字段均为小写。但最新版的支付后台生成签名使用的timeStamp字段名需大写其中的S字符
	    nonceStr: '', // 支付签名随机串,不长于 32 位
	    package: '', // 统一支付接口返回的prepay_id参数值,提交格式如:prepay_id=***)
	    signType: '', // 签名方式,默认为'SHA1',使用新版支付需传入'MD5'
	    paySign: '', // 支付签名
	    success: function (res) {
	        // 支付成功后的回调函数
	    },
	    cancel: function (res) {
	        // 取消支付后的回调函数
	    }
	});
    // config信息验证后会执行ready方法,所有接口调用都必须在config接口获得结果之后,config是一个客户端的异步操作,所以如果需要在页面加载时就调用相关接口,则须把相关接口放在ready函数中调用来确保正确执行。对于用户触发时才调用的接口,则可以直接调用,不需要放在ready函数中。
});


你可能感兴趣的:(微信小程序和公众号开发)