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 @   小草1234  阅读(757)  评论(0编辑  收藏  举报
编辑推荐:
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
阅读排行:
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
点击右上角即可分享
微信分享提示