java项目测试支付异步通知接口
1、需求说明
在进行支付的时候,总会有一个异步通知接口,他才是判断支付成功的重要依据。但是这个接口是第三方平台主动调用我们的接口,不能调试,只能通过打印日志来出来。但是有些公司接口文档说得不是很清楚,所以不知道他们返回的数据格式。
@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===========================");
// 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());
}
}
}