一、需求說明app
在進行支付的時候,總會有一個異步通知接口,他纔是判斷支付成功的重要依據。可是這個接口是第三方平臺主動調用咱們的接口,不能調試,只能經過打印日誌來出來。可是有些公司接口文檔說得不是很清楚,因此不知道他們返回的數據格式。異步
@RequestMapping("notifyUrl")
@SuppressWarnings({ "rawtypes" })
public void notifyUrl(HttpServletRequest request, HttpServletResponse response) {
log.info("----------->>>>YiBuToZhi------>>>>>");
Map<String, String> map = new HashMap<String, String>();
Enumeration paramNames = request.getParameterNames();
while (paramNames.hasMoreElements()) {
String paramName = (String) paramNames.nextElement();
String[] paramValues = request.getParameterValues(paramName);
if (paramValues.length == 1) {
if (paramValues[0].length() != 0) {
map.put(paramName, paramValues[0]);
}
}
}
// 打印map全部值
Set<Map.Entry<String, String>> set = map.entrySet();
log.info("===========================");
for (Map.Entry entry : set) {
log.info(entry.getKey() + ":" + entry.getValue());
}
log.info("END===========================");spa
// TODO
String rps = request.getParameter("rps");
log.info("rps={}", rps);
JSONObject rp = JSON.parseObject(rps);
String jsStatus = rp.get("status").toString();
log.info("status={}", jsStatus);
// 獲取通商雲訂單號
String orderNo = JSON.parseObject(rp.getString("returnValue")).getString("orderNo");
log.info("orderNo={}", orderNo);
if (jsStatus.equals("OK")) {
TblOrder order = tblOrderService.findByOrderNo(orderNo);
if (order != null) {
order.setPayStatus((byte) 0);
tblOrderService.save(order);
tblContractPreService.paySuccess(order.getDeedsn(),order.getBillNo());調試
}
}
}日誌