微信的统一下单接口(https://api.mch.weixin.qq.com/pay/unifiedorder)中,下单时,有这样一个参数:notify_url,该参数是为接收微信支付异步通知回调的地址,通知url必须为直接可访问的url,不能携带参数。之前我做回调的时候,为了性能方面的考虑,没有使用这种方式,而是在这个方法中:
wx.ready(function(){
wx.chooseWXPay({
"timestamp": timestamp, // 支付签名时间戳,注意微信jssdk中的所有使用timestamp字段均为小写。但最新版的支付后台生成签名使用的timeStamp字段名需大写其中的S字符
"nonceStr": nonceStr, // 支付签名随机串,不长于 32 位
"package": 'prepay_id=' + prepayId, // 统一支付接口返回的prepay_id参数值,提交格式如:prepay_id=***)
"signType": 'MD5', // 签名方式,默认为'SHA1',使用新版支付需传入'MD5'
"paySign": paySign, // 支付签名
success: function (res) {
//支付成功
},
cancel:function(res){
//支付取消
},
fail:function(res){
//支付失败
}
});
});
wx.config({
appId: appId, // 必填,公众号的唯一标识
timestamp: timestamp, // 必填,生成签名的时间戳
nonceStr: nonceStr, // 必填,生成签名的随机串
signature: signature,// 必填,签名,见附录1
jsApiList: ['onMenuShareAppMessage','onMenuShareQQ','onMenuShareWeibo','onMenuShareQZone','onMenuShareTimeline'] // 必填,需要使用的JS接口列表,所有JS接口列表见附录2
});
wx.error(function(res){
alert(res.errMsg);
});
wx.ready(function(){
//分享到聊天
wx.onMenuShareAppMessage({
title: shareTitle, // 分享标题
desc: shareDesc, // 分享描述
imgUrl: shareImg,//分享图片
success: function () {
// 用户确认分享后执行的回调函数
},
cancel: function () {
// 用户取消分享后执行的回调函数
}
});
//分享到QQ
wx.onMenuShareQQ({
title: shareTitle, // 分享标题
desc: shareDesc, // 分享描述
imgUrl: shareImg,//分享图片
success: function () {
// 用户确认分享后执行的回调函数
},
cancel: function () {
// 用户取消分享后执行的回调函数
}
});
//分享到微博
wx.onMenuShareWeibo({
title: shareTitle, // 分享标题
desc: shareDesc, // 分享描述
imgUrl: shareImg,//分享图片
success: function () {
// 用户确认分享后执行的回调函数
},
cancel: function () {
// 用户取消分享后执行的回调函数
}
});
//分享到qq空间
wx.onMenuShareQZone({
title: shareTitle, // 分享标题
desc: shareDesc, // 分享描述
imgUrl: shareImg,//分享图片
success: function () {
// 用户确认分享后执行的回调函数
},
cancel: function () {
// 用户取消分享后执行的回调函数
}
});
//分享到朋友圈
wx.onMenuShareTimeline({
title: shareTitle, // 分享标题
desc: shareDesc, // 分享描述
imgUrl: shareImg,//分享图片
success: function () {
// 用户确认分享后执行的回调函数
},
cancel: function () {
// 用户取消分享后执行的回调函数
}
});
});
var timestamp;
var nonceStr;
var signature;
//这里要特别强调这个url,获取signature时提供的url,一定要用这种方法,
//encodeURIComponent类似于java中的URIEncoding.encode方法,因为当url中有传递的参数时,如果不加密就会报错
var url = encodeURIComponent(location.href.split('#')[0]);
$.ajax({
type: "POST",
async: false,
url: "${pageContext.request.contextPath }/course/getJsSdk.action",
data:"url="+url,
success: function(msg){
var msgArr = msg.split("##");
timestamp = msgArr[0];
nonceStr = msgArr[1];
signature = msgArr[2];
},
error: function(msg){
alert("数据错误!");
}
});
/**
* 获取JsSdk的信息
* @throws Exception
*/
@Action("getJsSdk")
public void getJsSdk() throws Exception{
String url = request.getParameter("url");
log.info("url = " + url);
String ticket = AdvancedUtil.getTicket(WSPostUtil.getToken());
jssdk = JsSdkUtil.getSignature(ticket,url);
printInfo(jssdk.getTimestamp() + "##" + jssdk.getNoncestr() + "##" + jssdk.getSignature());
}