之前对接过微信支付的App支付,许久未用后测试人员发现微信支付不管用了,密钥,商户号,AppId都验证过,而且后台预支付单号也拿到了,摸索了一天,最后发现原来微信App支付官方文档签名生成方式已经改了!!!
改成了下面这样子的:
原来是这样的
接下来说说我的下面说说我签名的生成和请求调用:
服务器后台生成签名:
如果没有搭建好微信支付服务器的环境还需先配置跟搭建环境:
https://pay.weixin.qq.com/wiki/doc/apiv3/open/pay/chapter2_5_2.shtml#menu3
构造签名串:
public String buildMessage(String appId, String timestamp, String nonceStr, String prepayId) {
return appId + "\n"
+ timestamp + "\n"
+ nonceStr + "\n"
+ prepayId + "\n";
}
计算签名值:
public String sign(byte[] message) throws NoSuchAlgorithmException, SignatureException, InvalidKeyException {
Signature sign = Signature.getInstance("SHA256withRSA");
sign.initSign(merchantPrivateKey);
sign.update(message);
return Base64.getEncoder().encodeToString(sign.sign());
}
注意:PrivateKey类型的merchantPrivateKey是根据证书生成的商户密钥:
具体看:
https://github.com/wechatpay-apiv3/wechatpay-apache-httpclient
最后将计算好的签名值 与 应用ID、商户号、预支付交易会话ID、随机字符串、时间戳、订单详情扩展字符串返回到客户端,客户端进行请求,调起支付
客户端调起支付:
PayReq payRequest = new PayReq();
payRequest.appId = returnPayRequestBean.getAppId();
payRequest.partnerId = returnPayRequestBean.getMchId();
payRequest.prepayId = returnPayRequestBean.getPrepayId();
payRequest.nonceStr = returnPayRequestBean.getNonceStr();
payRequest.timeStamp = returnPayRequestBean.getTimeStamp();
payRequest.packageValue = "Sign=WXPay";
payRequest.sign = returnPayRequestBean.getSign();
api.sendReq(payRequest);
最后补上android微信APP支付的客户端的实例代码地址:
https://developers.weixin.qq.com/doc/oplatform/Downloads/Android_Resource.html