java項目測試支付異步通知接口

一、需求說明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());調試

            }
        }
    }日誌

相關文章
相關標籤/搜索