package com.java110.boot.smo.payment.impl; import com.java110.boot.smo.AppAbstractComponentSMO; import com.java110.boot.smo.payment.IToNotifySMO; import com.java110.boot.smo.payment.adapt.IPayNotifyAdapt; import com.java110.core.log.LoggerFactory; import com.java110.utils.cache.MappingCache; import com.java110.utils.constant.WechatConstant; import com.java110.utils.factory.ApplicationContextFactory; import com.java110.utils.util.StringUtil; import org.slf4j.Logger; import org.springframework.http.HttpStatus; import org.springframework.http.ResponseEntity; import org.springframework.stereotype.Service; import javax.servlet.http.HttpServletRequest; @Service("toNotifySMOImpl") public class ToNotifySMOImpl implements IToNotifySMO { private static final Logger logger = LoggerFactory.getLogger(AppAbstractComponentSMO.class); private static final String DEFAULT_PAY_NOTIFY_ADAPT = "wechatPayNotifyAdapt";// 默认微信通用支付 @Override public ResponseEntity toNotify(String param, HttpServletRequest request) { String wId = request.getParameter("wId"); String payNotifyAdapt = MappingCache.getValue(WechatConstant.WECHAT_DOMAIN, WechatConstant.PAY_NOTIFY_ADAPT); payNotifyAdapt = StringUtil.isEmpty(payNotifyAdapt) ? DEFAULT_PAY_NOTIFY_ADAPT : payNotifyAdapt; //支付适配器IPayNotifyAdapt logger.debug("适配器:" + payNotifyAdapt); IPayNotifyAdapt tPayNotifyAdapt = ApplicationContextFactory.getBean(payNotifyAdapt, IPayNotifyAdapt.class); String resXml = tPayNotifyAdapt.confirmPayFee(param, wId); logger.info("【小程序支付回调响应】 响应内容:\n" + resXml); return new ResponseEntity(resXml, HttpStatus.OK); } }