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());

            }
        }
    }

posted @ 2020-04-09 15:45  小草1234  阅读(754)  评论(0编辑  收藏  举报