• 支付宝手机网站支付验签失败解决办法


    验签传入的参数map集合、支付宝公钥、编码格式(UTF-8,GBK....)

    主要验签失败的原因是map集合中存放的值是不正确的

    下面列出map集合中需要放入的参数值

           paramsMap.put("sign",实际取到的sign值,下同。。);
                paramsMap.put("gmt_create",);
                paramsMap.put("gmt_payment",);
                paramsMap.put("notify_time",);
                paramsMap.put("subject",);
                paramsMap.put("buyer_id",);
                paramsMap.put("notify_id",);
                paramsMap.put("notify_type",);
                paramsMap.put("out_trade_no",);
                paramsMap.put("total_amount",);
                paramsMap.put("trade_status",);
                paramsMap.put("trade_no",);
                paramsMap.put("app_id",);
                paramsMap.put("seller_id",);

     如果使用的是springmvc框架,可以直接使用以下的代码进行验证

    @RequestMapping("/yanqian")
        @ResponseBody
        public void tuikaun1(HttpServletRequest request,HttpServletResponse httpResponse) throws ServletException, IOException, AlipayApiException {
            Map<String,String> params = new HashMap<String,String>();
            Map requestParams = request.getParameterMap();
            for (Iterator iter = requestParams.keySet().iterator(); iter.hasNext();) {
                String name = (String) iter.next();
                String[] values = (String[]) requestParams.get(name);
                String valueStr = "";
                for (int i = 0; i < values.length; i++) {
                    valueStr = (i == values.length - 1) ? valueStr + values[i]
                            : valueStr + values[i] + ",";
                }
                //乱码解决,这段代码在出现乱码时使用。如果mysign和sign不相等也可以使用这段代码转化
                //valueStr = new String(valueStr.getBytes("ISO-8859-1"), "gbk");
                params.put(name, valueStr);
            }
            System.out.println(params);
            boolean    signVerified = AlipaySignature.rsaCheckV1(params, ALIPAY_PUBLIC_KEY, "utf-8");
            System.out.println("signVerified======"+signVerified);
            
        }
  • 相关阅读:
    Linux sudo权限提升漏洞(CVE-2021-3156)复现
    CVE-2021-3129-Laravel Debug mode 远程代码执行漏洞
    maven项目在jenkins上以配置文件及Git分支作为参数执行构建
    jenkins 配置参数执行
    maven+java+tesng 遇到的坑
    IDEA的使用及初始化
    python发邮件之邮件内放入表格
    maven作用
    java自动化学习笔记
    在电脑端同时安装Python2,Python3
  • 原文地址:https://www.cnblogs.com/guokai870510826/p/6061470.html
Copyright © 2020-2023  润新知