Authored by LUOXC

Merge branch 'dev-wechat' into test6.9.14

# Conflicts:
#	order/src/main/java/com/yohoufo/order/service/pay/weixin/AbstractWeixinPayService.java
@@ -56,6 +56,8 @@ public class WeixinPayConfig { @@ -56,6 +56,8 @@ public class WeixinPayConfig {
56 public static final String NONCE_STR = "nonce_str"; 56 public static final String NONCE_STR = "nonce_str";
57 //签名 57 //签名
58 public static final String SIGN = "sign"; 58 public static final String SIGN = "sign";
  59 + //签名类型
  60 + public static final String SIGN_TYPE = "sign_type";
59 //商品描述 61 //商品描述
60 public static final String BODY = "body"; 62 public static final String BODY = "body";
61 //商户订单号 63 //商户订单号
@@ -6,6 +6,8 @@ import com.yoho.core.security.WechatException; @@ -6,6 +6,8 @@ import com.yoho.core.security.WechatException;
6 import com.yoho.core.security.WechatHelper; 6 import com.yoho.core.security.WechatHelper;
7 import com.yoho.error.ServiceError; 7 import com.yoho.error.ServiceError;
8 import com.yoho.error.exception.ServiceException; 8 import com.yoho.error.exception.ServiceException;
  9 +import com.yohobuy.ufo.model.order.bo.OrderInfo;
  10 +import com.yohobuy.ufo.model.order.bo.OutTradeNoMeta;
9 import com.yohobuy.ufo.model.order.bo.PaymentData; 11 import com.yohobuy.ufo.model.order.bo.PaymentData;
10 import com.yohoufo.common.utils.DateUtil; 12 import com.yohoufo.common.utils.DateUtil;
11 import com.yohoufo.common.utils.HttpClient; 13 import com.yohoufo.common.utils.HttpClient;
@@ -13,12 +15,10 @@ import com.yohoufo.common.utils.TimeUtils; @@ -13,12 +15,10 @@ import com.yohoufo.common.utils.TimeUtils;
13 import com.yohoufo.common.utils.WXUtils; 15 import com.yohoufo.common.utils.WXUtils;
14 import com.yohoufo.order.config.WeixinPayConfig; 16 import com.yohoufo.order.config.WeixinPayConfig;
15 import com.yohoufo.order.constants.RefundContant; 17 import com.yohoufo.order.constants.RefundContant;
16 -import com.yohobuy.ufo.model.order.bo.OrderInfo;  
17 import com.yohoufo.order.model.PayQueryBo; 18 import com.yohoufo.order.model.PayQueryBo;
18 import com.yohoufo.order.model.PayRefundBo; 19 import com.yohoufo.order.model.PayRefundBo;
19 import com.yohoufo.order.service.PaymentSupportService; 20 import com.yohoufo.order.service.PaymentSupportService;
20 import com.yohoufo.order.service.pay.AbstractPayService; 21 import com.yohoufo.order.service.pay.AbstractPayService;
21 -import com.yohobuy.ufo.model.order.bo.OutTradeNoMeta;  
22 import org.apache.commons.lang3.StringUtils; 22 import org.apache.commons.lang3.StringUtils;
23 import org.slf4j.Logger; 23 import org.slf4j.Logger;
24 import org.slf4j.LoggerFactory; 24 import org.slf4j.LoggerFactory;
@@ -28,6 +28,7 @@ import org.springframework.beans.factory.annotation.Value; @@ -28,6 +28,7 @@ import org.springframework.beans.factory.annotation.Value;
28 import java.util.HashMap; 28 import java.util.HashMap;
29 import java.util.LinkedHashMap; 29 import java.util.LinkedHashMap;
30 import java.util.Map; 30 import java.util.Map;
  31 +import java.util.Objects;
31 32
32 import static com.yohoufo.order.utils.ServiceExceptions.throwServiceException; 33 import static com.yohoufo.order.utils.ServiceExceptions.throwServiceException;
33 34
@@ -70,7 +71,7 @@ public abstract class AbstractWeixinPayService extends AbstractPayService { @@ -70,7 +71,7 @@ public abstract class AbstractWeixinPayService extends AbstractPayService {
70 return false; 71 return false;
71 } 72 }
72 73
73 - if(!md5SignVerify(paramsMap)) { 74 + if(!verifySign(paramsMap)) {
74 log.error("[{}] sign verify failed", paramsMap.get("out_trade_no")); 75 log.error("[{}] sign verify failed", paramsMap.get("out_trade_no"));
75 return false; 76 return false;
76 } 77 }
@@ -161,18 +162,12 @@ public abstract class AbstractWeixinPayService extends AbstractPayService { @@ -161,18 +162,12 @@ public abstract class AbstractWeixinPayService extends AbstractPayService {
161 * @return 162 * @return
162 */ 163 */
163 private Map<String, String> buildPayQureyParams(String tradeNo) { 164 private Map<String, String> buildPayQureyParams(String tradeNo) {
164 -  
165 Map<String, String> paramMap = new HashMap<String, String>(); 165 Map<String, String> paramMap = new HashMap<String, String>();
166 - // RequestBuilder builder = new RequestBuilder();  
167 paramMap.put("appid", getAppId()); 166 paramMap.put("appid", getAppId());
168 paramMap.put("mch_id", getMchId()); 167 paramMap.put("mch_id", getMchId());
169 paramMap.put("out_trade_no", tradeNo); 168 paramMap.put("out_trade_no", tradeNo);
170 paramMap.put("nonce_str", WXUtils.getNonceStr()); 169 paramMap.put("nonce_str", WXUtils.getNonceStr());
171 -  
172 - //md5签名  
173 - String sign = signByMD5(paramMap);  
174 - paramMap.put(WeixinPayConfig.ApiConstants.SIGN, sign);  
175 - return paramMap; 170 + return withHmacSha256Sign(paramMap);
176 } 171 }
177 172
178 protected String signByMD5(Map<String, String> signParams) { 173 protected String signByMD5(Map<String, String> signParams) {
@@ -189,6 +184,27 @@ public abstract class AbstractWeixinPayService extends AbstractPayService { @@ -189,6 +184,27 @@ public abstract class AbstractWeixinPayService extends AbstractPayService {
189 return sign; 184 return sign;
190 } 185 }
191 186
  187 + protected Map<String, String> withHmacSha256Sign(Map<String, String> signParams){
  188 + String sign = hmacSha256(signParams);
  189 + signParams.put(WeixinPayConfig.ApiConstants.SIGN, sign);
  190 + signParams.put(WeixinPayConfig.ApiConstants.SIGN_TYPE, "HMAC-SHA256");
  191 + return signParams;
  192 + }
  193 +
  194 + protected String hmacSha256(Map<String, String> signParams) {
  195 + String sign;
  196 + try {
  197 +
  198 + sign = wechatHelper.signByHmacSha256(getMchId(), WXUtils.buildPreSignContent(signParams).toString());
  199 +
  200 + } catch (WechatException e) {
  201 + log.info("wechat sign fail", e);
  202 + throwServiceException("微信签名失败");
  203 + sign = StringUtils.EMPTY;
  204 + }
  205 + return sign;
  206 + }
  207 +
192 208
193 public PaymentData getPaymentData(Map<String, String> paramsMap) { 209 public PaymentData getPaymentData(Map<String, String> paramsMap) {
194 PaymentData paymentData = new PaymentData(); 210 PaymentData paymentData = new PaymentData();
@@ -322,11 +338,7 @@ public abstract class AbstractWeixinPayService extends AbstractPayService { @@ -322,11 +338,7 @@ public abstract class AbstractWeixinPayService extends AbstractPayService {
322 paramMap.put("op_user_id", getMchId()); 338 paramMap.put("op_user_id", getMchId());
323 339
324 //签名 340 //签名
325 - //md5签名  
326 - String sign = signByMD5(paramMap);  
327 - paramMap.put(WeixinPayConfig.ApiConstants.SIGN, sign);  
328 -  
329 - return paramMap; 341 + return withHmacSha256Sign(paramMap);
330 } 342 }
331 343
332 344
@@ -388,9 +400,9 @@ public abstract class AbstractWeixinPayService extends AbstractPayService { @@ -388,9 +400,9 @@ public abstract class AbstractWeixinPayService extends AbstractPayService {
388 signParams.put("package", WeixinPayConfig.ApiConstants.RETURN_PREPAY_ID + "=" + prepayId); 400 signParams.put("package", WeixinPayConfig.ApiConstants.RETURN_PREPAY_ID + "=" + prepayId);
389 signParams.put("nonceStr", requestParams.get(WeixinPayConfig.ApiConstants.NONCE_STR)); 401 signParams.put("nonceStr", requestParams.get(WeixinPayConfig.ApiConstants.NONCE_STR));
390 signParams.put("timeStamp", timeStamp); 402 signParams.put("timeStamp", timeStamp);
391 - signParams.put("signType", "MD5"); 403 + signParams.put("signType", "HMAC-SHA256");
392 404
393 - String sign = signByMD5(signParams); 405 + String sign = hmacSha256(signParams);
394 406
395 JSONObject prepayJson = new JSONObject(); 407 JSONObject prepayJson = new JSONObject();
396 prepayJson.put("timeStamp", signParams.get("timeStamp")); 408 prepayJson.put("timeStamp", signParams.get("timeStamp"));
@@ -424,8 +436,7 @@ public abstract class AbstractWeixinPayService extends AbstractPayService { @@ -424,8 +436,7 @@ public abstract class AbstractWeixinPayService extends AbstractPayService {
424 prePayData.put("noncestr", requestParams.get(WeixinPayConfig.ApiConstants.NONCE_STR)); 436 prePayData.put("noncestr", requestParams.get(WeixinPayConfig.ApiConstants.NONCE_STR));
425 prePayData.put("timestamp", timeStamp); 437 prePayData.put("timestamp", timeStamp);
426 438
427 - String sign = signByMD5(prePayData);  
428 - prePayData.put("sign", sign); 439 + withHmacSha256Sign(prePayData);
429 440
430 JSONObject sendData = new JSONObject(); 441 JSONObject sendData = new JSONObject();
431 sendData.put("prePayUrl", weixinPayConfig.prepayUrl()); //实际上没用,为兼容APP,暂且保留 442 sendData.put("prePayUrl", weixinPayConfig.prepayUrl()); //实际上没用,为兼容APP,暂且保留
@@ -457,7 +468,7 @@ public abstract class AbstractWeixinPayService extends AbstractPayService { @@ -457,7 +468,7 @@ public abstract class AbstractWeixinPayService extends AbstractPayService {
457 } 468 }
458 469
459 //验证签名 470 //验证签名
460 - if(!md5SignVerify(reponseMap)){ 471 + if(!verifySign(reponseMap)){
461 log.error("[{}] sign verify failed", orderCode); 472 log.error("[{}] sign verify failed", orderCode);
462 return false; 473 return false;
463 } 474 }
@@ -471,17 +482,17 @@ public abstract class AbstractWeixinPayService extends AbstractPayService { @@ -471,17 +482,17 @@ public abstract class AbstractWeixinPayService extends AbstractPayService {
471 } 482 }
472 483
473 484
474 - /**  
475 - * 验证MD5签名  
476 - * @param paramsMap  
477 - * @return  
478 - */  
479 - public boolean md5SignVerify(Map<String, String> paramsMap) {  
480 - if(paramsMap == null) 485 + public boolean verifySign(Map<String, String> paramsMap) {
  486 + if (paramsMap == null) {
481 return false; 487 return false;
482 - 488 + }
  489 + String signType = paramsMap.get(WeixinPayConfig.ApiConstants.SIGN_TYPE);
  490 + if (Objects.equals(signType, "HMAC-SHA256")) {
  491 + return hmacSha256(paramsMap).equals(paramsMap.get(WeixinPayConfig.ApiConstants.SIGN));
  492 + } else {
483 return signByMD5(paramsMap).equals(paramsMap.get(WeixinPayConfig.ApiConstants.SIGN)); 493 return signByMD5(paramsMap).equals(paramsMap.get(WeixinPayConfig.ApiConstants.SIGN));
484 } 494 }
  495 + }
485 496
486 /** 497 /**
487 * 预支付请求 498 * 预支付请求
@@ -536,11 +547,7 @@ public abstract class AbstractWeixinPayService extends AbstractPayService { @@ -536,11 +547,7 @@ public abstract class AbstractWeixinPayService extends AbstractPayService {
536 parameters.put(WeixinPayConfig.ApiConstants.LIMIT_PAY, WeixinPayConfig.ApiConstants.NO_CREDIT); 547 parameters.put(WeixinPayConfig.ApiConstants.LIMIT_PAY, WeixinPayConfig.ApiConstants.NO_CREDIT);
537 } 548 }
538 549
539 - //md5签名  
540 - String sign = signByMD5(parameters);  
541 - parameters.put(WeixinPayConfig.ApiConstants.SIGN, sign);  
542 -  
543 - return parameters; 550 + return withHmacSha256Sign(parameters);
544 } 551 }
545 552
546 private String getPayExpireTimeStr(OrderInfo orderInfo){ 553 private String getPayExpireTimeStr(OrderInfo orderInfo){