mirror of
https://gitee.com/binary/weixin-java-tools.git
synced 2025-04-05 17:38:05 +08:00
优化微信支付代码,避免过度检查
This commit is contained in:
parent
6cabfc3e12
commit
57eab45c81
@ -215,8 +215,10 @@ public abstract class WxPayBaseResult {
|
||||
|
||||
/**
|
||||
* 校验返回结果签名
|
||||
*
|
||||
* @param checkSuccess 是否同时检查结果是否成功
|
||||
*/
|
||||
public void checkResult(WxPayServiceAbstractImpl wxPayService) throws WxPayException {
|
||||
public void checkResult(WxPayServiceAbstractImpl wxPayService, boolean checkSuccess) throws WxPayException {
|
||||
//校验返回结果签名
|
||||
Map<String, String> map = toMap();
|
||||
if (getSign() != null && !SignUtils.checkSign(map, wxPayService.getConfig().getMchKey())) {
|
||||
@ -224,29 +226,31 @@ public abstract class WxPayBaseResult {
|
||||
throw new WxPayException("参数格式校验错误!");
|
||||
}
|
||||
|
||||
List<String> successStrings = Lists.newArrayList("SUCCESS", "");
|
||||
//校验结果是否成功
|
||||
if (!successStrings.contains(StringUtils.trimToEmpty(getReturnCode()).toUpperCase())
|
||||
|| !successStrings.contains(StringUtils.trimToEmpty(getResultCode()).toUpperCase())) {
|
||||
StringBuilder errorMsg = new StringBuilder();
|
||||
if (getReturnCode() != null) {
|
||||
errorMsg.append("返回代码:").append(getReturnCode());
|
||||
}
|
||||
if (getReturnMsg() != null) {
|
||||
errorMsg.append(",返回信息:").append(getReturnMsg());
|
||||
}
|
||||
if (getResultCode() != null) {
|
||||
errorMsg.append(",结果代码:").append(getResultCode());
|
||||
}
|
||||
if (getErrCode() != null) {
|
||||
errorMsg.append(",错误代码:").append(getErrCode());
|
||||
}
|
||||
if (getErrCodeDes() != null) {
|
||||
errorMsg.append(",错误详情:").append(getErrCodeDes());
|
||||
}
|
||||
if (checkSuccess) {
|
||||
List<String> successStrings = Lists.newArrayList("SUCCESS", "");
|
||||
if (!successStrings.contains(StringUtils.trimToEmpty(getReturnCode()).toUpperCase())
|
||||
|| !successStrings.contains(StringUtils.trimToEmpty(getResultCode()).toUpperCase())) {
|
||||
StringBuilder errorMsg = new StringBuilder();
|
||||
if (getReturnCode() != null) {
|
||||
errorMsg.append("返回代码:").append(getReturnCode());
|
||||
}
|
||||
if (getReturnMsg() != null) {
|
||||
errorMsg.append(",返回信息:").append(getReturnMsg());
|
||||
}
|
||||
if (getResultCode() != null) {
|
||||
errorMsg.append(",结果代码:").append(getResultCode());
|
||||
}
|
||||
if (getErrCode() != null) {
|
||||
errorMsg.append(",错误代码:").append(getErrCode());
|
||||
}
|
||||
if (getErrCodeDes() != null) {
|
||||
errorMsg.append(",错误详情:").append(getErrCodeDes());
|
||||
}
|
||||
|
||||
this.getLogger().error("\n结果业务代码异常,返回結果:{},\n{}", map, errorMsg.toString());
|
||||
throw WxPayException.from(this);
|
||||
this.getLogger().error("\n结果业务代码异常,返回結果:{},\n{}", map, errorMsg.toString());
|
||||
throw WxPayException.from(this);
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -77,7 +77,7 @@ public abstract class WxPayServiceAbstractImpl implements WxPayService {
|
||||
String url = this.getPayBaseUrl() + "/secapi/pay/refund";
|
||||
String responseContent = this.post(url, request.toXML(), true);
|
||||
WxPayRefundResult result = WxPayBaseResult.fromXML(responseContent, WxPayRefundResult.class);
|
||||
result.checkResult(this);
|
||||
result.checkResult(this, true);
|
||||
return result;
|
||||
}
|
||||
|
||||
@ -96,7 +96,7 @@ public abstract class WxPayServiceAbstractImpl implements WxPayService {
|
||||
String responseContent = this.post(url, request.toXML(), false);
|
||||
WxPayRefundQueryResult result = WxPayBaseResult.fromXML(responseContent, WxPayRefundQueryResult.class);
|
||||
result.composeRefundRecords();
|
||||
result.checkResult(this);
|
||||
result.checkResult(this, true);
|
||||
return result;
|
||||
}
|
||||
|
||||
@ -112,7 +112,7 @@ public abstract class WxPayServiceAbstractImpl implements WxPayService {
|
||||
log.debug("微信支付异步通知请求参数:{}", xmlData);
|
||||
WxPayOrderNotifyResult result = WxPayOrderNotifyResult.fromXML(xmlData);
|
||||
log.debug("微信支付异步通知请求解析后的对象:{}", result);
|
||||
result.checkResult(this);
|
||||
result.checkResult(this, false);
|
||||
return result;
|
||||
} catch (WxPayException e) {
|
||||
log.error(e.getMessage(), e);
|
||||
@ -163,7 +163,7 @@ public abstract class WxPayServiceAbstractImpl implements WxPayService {
|
||||
String url = this.getPayBaseUrl() + "/mmpaymkttransfers/gethbinfo";
|
||||
String responseContent = this.post(url, request.toXML(), true);
|
||||
WxPayRedpackQueryResult result = WxPayBaseResult.fromXML(responseContent, WxPayRedpackQueryResult.class);
|
||||
result.checkResult(this);
|
||||
result.checkResult(this, true);
|
||||
return result;
|
||||
}
|
||||
|
||||
@ -182,7 +182,7 @@ public abstract class WxPayServiceAbstractImpl implements WxPayService {
|
||||
|
||||
WxPayOrderQueryResult result = WxPayBaseResult.fromXML(responseContent, WxPayOrderQueryResult.class);
|
||||
result.composeCoupons();
|
||||
result.checkResult(this);
|
||||
result.checkResult(this, true);
|
||||
return result;
|
||||
}
|
||||
|
||||
@ -199,7 +199,7 @@ public abstract class WxPayServiceAbstractImpl implements WxPayService {
|
||||
String url = this.getPayBaseUrl() + "/pay/closeorder";
|
||||
String responseContent = this.post(url, request.toXML(), false);
|
||||
WxPayOrderCloseResult result = WxPayBaseResult.fromXML(responseContent, WxPayOrderCloseResult.class);
|
||||
result.checkResult(this);
|
||||
result.checkResult(this, true);
|
||||
|
||||
return result;
|
||||
}
|
||||
@ -272,11 +272,12 @@ public abstract class WxPayServiceAbstractImpl implements WxPayService {
|
||||
String url = this.getPayBaseUrl() + "/pay/unifiedorder";
|
||||
String responseContent = this.post(url, request.toXML(), false);
|
||||
WxPayUnifiedOrderResult result = WxPayBaseResult.fromXML(responseContent, WxPayUnifiedOrderResult.class);
|
||||
result.checkResult(this);
|
||||
result.checkResult(this, true);
|
||||
return result;
|
||||
}
|
||||
|
||||
@Override
|
||||
@Deprecated
|
||||
public Map<String, String> getPayInfo(WxPayUnifiedOrderRequest request) throws WxPayException {
|
||||
WxPayUnifiedOrderResult unifiedOrderResult = this.unifiedOrder(request);
|
||||
String prepayId = unifiedOrderResult.getPrepayId();
|
||||
@ -331,7 +332,7 @@ public abstract class WxPayServiceAbstractImpl implements WxPayService {
|
||||
|
||||
String responseContent = this.post(url, request.toXML(), true);
|
||||
WxEntPayResult result = WxPayBaseResult.fromXML(responseContent, WxEntPayResult.class);
|
||||
result.checkResult(this);
|
||||
result.checkResult(this, true);
|
||||
return result;
|
||||
}
|
||||
|
||||
@ -344,7 +345,7 @@ public abstract class WxPayServiceAbstractImpl implements WxPayService {
|
||||
String url = this.getPayBaseUrl() + "/mmpaymkttransfers/gettransferinfo";
|
||||
String responseContent = this.post(url, request.toXML(), true);
|
||||
WxEntPayQueryResult result = WxPayBaseResult.fromXML(responseContent, WxEntPayQueryResult.class);
|
||||
result.checkResult(this);
|
||||
result.checkResult(this, true);
|
||||
return result;
|
||||
}
|
||||
|
||||
@ -396,7 +397,7 @@ public abstract class WxPayServiceAbstractImpl implements WxPayService {
|
||||
String url = this.getPayBaseUrl() + "/payitil/report";
|
||||
String responseContent = this.post(url, request.toXML(), false);
|
||||
WxPayCommonResult result = WxPayBaseResult.fromXML(responseContent, WxPayCommonResult.class);
|
||||
result.checkResult(this);
|
||||
result.checkResult(this, true);
|
||||
}
|
||||
|
||||
@Override
|
||||
@ -494,7 +495,7 @@ public abstract class WxPayServiceAbstractImpl implements WxPayService {
|
||||
String url = this.getPayBaseUrl() + "/pay/micropay";
|
||||
String responseContent = this.post(url, request.toXML(), false);
|
||||
WxPayMicropayResult result = WxPayBaseResult.fromXML(responseContent, WxPayMicropayResult.class);
|
||||
result.checkResult(this);
|
||||
result.checkResult(this, true);
|
||||
return result;
|
||||
}
|
||||
|
||||
@ -505,7 +506,7 @@ public abstract class WxPayServiceAbstractImpl implements WxPayService {
|
||||
String url = this.getPayBaseUrl() + "/secapi/pay/reverse";
|
||||
String responseContent = this.post(url, request.toXML(), true);
|
||||
WxPayOrderReverseResult result = WxPayBaseResult.fromXML(responseContent, WxPayOrderReverseResult.class);
|
||||
result.checkResult(this);
|
||||
result.checkResult(this, true);
|
||||
return result;
|
||||
}
|
||||
|
||||
@ -516,7 +517,7 @@ public abstract class WxPayServiceAbstractImpl implements WxPayService {
|
||||
String url = this.getPayBaseUrl() + "/tools/shorturl";
|
||||
String responseContent = this.post(url, request.toXML(), false);
|
||||
WxPayShorturlResult result = WxPayBaseResult.fromXML(responseContent, WxPayShorturlResult.class);
|
||||
result.checkResult(this);
|
||||
result.checkResult(this, true);
|
||||
return result.getShortUrl();
|
||||
}
|
||||
|
||||
@ -532,7 +533,7 @@ public abstract class WxPayServiceAbstractImpl implements WxPayService {
|
||||
String url = this.getPayBaseUrl() + "/tools/authcodetoopenid";
|
||||
String responseContent = this.post(url, request.toXML(), false);
|
||||
WxPayAuthcode2OpenidResult result = WxPayBaseResult.fromXML(responseContent, WxPayAuthcode2OpenidResult.class);
|
||||
result.checkResult(this);
|
||||
result.checkResult(this, true);
|
||||
return result.getOpenid();
|
||||
}
|
||||
|
||||
@ -549,7 +550,7 @@ public abstract class WxPayServiceAbstractImpl implements WxPayService {
|
||||
String url = "https://api.mch.weixin.qq.com/sandboxnew/pay/getsignkey";
|
||||
String responseContent = this.post(url, request.toXML(), false);
|
||||
WxPaySandboxSignKeyResult result = WxPayBaseResult.fromXML(responseContent, WxPaySandboxSignKeyResult.class);
|
||||
result.checkResult(this);
|
||||
result.checkResult(this, true);
|
||||
return result.getSandboxSignKey();
|
||||
}
|
||||
|
||||
@ -560,7 +561,7 @@ public abstract class WxPayServiceAbstractImpl implements WxPayService {
|
||||
String url = this.getPayBaseUrl() + "/mmpaymkttransfers/send_coupon";
|
||||
String responseContent = this.post(url, request.toXML(), true);
|
||||
WxPayCouponSendResult result = WxPayBaseResult.fromXML(responseContent, WxPayCouponSendResult.class);
|
||||
result.checkResult(this);
|
||||
result.checkResult(this, true);
|
||||
return result;
|
||||
}
|
||||
|
||||
@ -571,7 +572,7 @@ public abstract class WxPayServiceAbstractImpl implements WxPayService {
|
||||
String url = this.getPayBaseUrl() + "/mmpaymkttransfers/query_coupon_stock";
|
||||
String responseContent = this.post(url, request.toXML(), false);
|
||||
WxPayCouponStockQueryResult result = WxPayBaseResult.fromXML(responseContent, WxPayCouponStockQueryResult.class);
|
||||
result.checkResult(this);
|
||||
result.checkResult(this, true);
|
||||
return result;
|
||||
}
|
||||
|
||||
@ -582,7 +583,7 @@ public abstract class WxPayServiceAbstractImpl implements WxPayService {
|
||||
String url = this.getPayBaseUrl() + "/mmpaymkttransfers/querycouponsinfo";
|
||||
String responseContent = this.post(url, request.toXML(), false);
|
||||
WxPayCouponInfoQueryResult result = WxPayBaseResult.fromXML(responseContent, WxPayCouponInfoQueryResult.class);
|
||||
result.checkResult(this);
|
||||
result.checkResult(this, true);
|
||||
return result;
|
||||
}
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user