收藏
回答

微信V3支付回调异常如何处理?

java.lang.NoSuchMethodError: com.fasterxml.jackson.databind.ObjectReader.readValue(Ljava/lang/String;Ljava/lang/Class;)Ljava/lang/Object;

at com.wechat.pay.contrib.apache.httpclient.notification.NotificationHandler.parseBody(NotificationHandler.java:85)

at com.wechat.pay.contrib.apache.httpclient.notification.NotificationHandler.parse(NotificationHandler.java:48)

at com.louis.kitty.wechat.service.impl.WechatPortServiceImpl.decryption(WechatPortServiceImpl.java:737)

at com.louis.kitty.wechat.service.impl.WechatPortServiceImpl.wechatAppRechargeNotify(WechatPortServiceImpl.java:892)

at com.louis.kitty.wechat.controller.PortController.wechatAppRechargeNotify(PortController.java:489)

at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)

at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source)

at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source)

at java.lang.reflect.Method.invoke(Unknown Source)

at org.springframework.web.method.support.InvocableHandlerMethod.doInvoke(InvocableHandlerMethod.java:209)

at org.springframework.web.method.support.InvocableHandlerMethod.invokeForRequest(InvocableHandlerMethod.java:136)

at org.springframework.web.servlet.mvc.method.annotation.ServletInvocableHandlerMethod.invokeAndHandle(ServletInvocableHandlerMethod.java:102)

at org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter.invokeHandlerMethod(RequestMappingHandlerAdapter.java:877)

at org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter.handleInternal(RequestMappingHandlerAdapter.java:783)

at org.springframework.web.servlet.mvc.method.AbstractHandlerMethodAdapter.handle(AbstractHandlerMethodAdapter.java:87)

at org.springframework.web.servlet.DispatcherServlet.doDispatch(DispatcherServlet.java:991)

at org.springframework.web.servlet.DispatcherServlet.doService(DispatcherServlet.java:925)

at org.springframework.web.servlet.FrameworkServlet.processRequest(FrameworkServlet.java:974)

at org.springframework.web.servlet.FrameworkServlet.doPost(FrameworkServlet.java:877)

at javax.servlet.http.HttpServlet.service(HttpServlet.java:661)

at org.springframework.web.servlet.FrameworkServlet.service(FrameworkServlet.java:851)

at javax.servlet.http.HttpServlet.service(HttpServlet.java:742)

at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:231)

at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166)

at org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:52)

at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:193)

at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166)

at com.alibaba.druid.support.http.WebStatFilter.doFilter(WebStatFilter.java:123)

at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:193)

at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166)

at org.springframework.boot.actuate.web.trace.servlet.HttpTraceFilter.doFilterInternal(HttpTraceFilter.java:90)

at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:107)

at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:193)

at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166)

at org.springframework.web.filter.RequestContextFilter.doFilterInternal(RequestContextFilter.java:99)

at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:107)

at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:193)

at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166)

at org.springframework.web.filter.HttpPutFormContentFilter.doFilterInternal(HttpPutFormContentFilter.java:109)

at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:107)

at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:193)

at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166)

at org.springframework.web.filter.HiddenHttpMethodFilter.doFilterInternal(HiddenHttpMethodFilter.java:93)

at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:107)

at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:193)

at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166)

at org.springframework.boot.actuate.metrics.web.servlet.WebMvcMetricsFilter.filterAndRecordMetrics(WebMvcMetricsFilter.java:155)

at org.springframework.boot.actuate.metrics.web.servlet.WebMvcMetricsFilter.filterAndRecordMetrics(WebMvcMetricsFilter.java:123)

at org.springframework.boot.actuate.metrics.web.servlet.WebMvcMetricsFilter.doFilterInternal(WebMvcMetricsFilter.java:108)

at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:107)

at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:193)

at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166)

at org.springframework.web.filter.CharacterEncodingFilter.doFilterInternal(CharacterEncodingFilter.java:200)

at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:107)

at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:193)

at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166)

at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:198)

at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:96)

at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:493)

at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:140)

at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:81)

at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:87)

at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:342)

at org.apache.coyote.http11.Http11Processor.service(Http11Processor.java:800)

at org.apache.coyote.AbstractProcessorLight.process(AbstractProcessorLight.java:66)

at org.apache.coyote.AbstractProtocol$ConnectionHandler.process(AbstractProtocol.java:800)

at org.apache.tomcat.util.net.NioEndpoint$SocketProcessor.doRun(NioEndpoint.java:1471)

at org.apache.tomcat.util.net.SocketProcessorBase.run(SocketProcessorBase.java:49)

at java.util.concurrent.ThreadPoolExecutor.runWorker(Unknown Source)

at java.util.concurrent.ThreadPoolExecutor$Worker.run(Unknown Source)

at org.apache.tomcat.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:61)

at java.lang.Thread.run(Unknown Source)



这个错误是出现在解析上的,源码如下


logger.debug("方法\"decryption\"接口返回参数,request:"+request);

WxAppPayConfig wxAppPayConfig=new WxAppPayConfig();

String HeadNonce = request.getHeader("Wechatpay-Nonce"); // 请求头Wechatpay-Nonce

logger.debug("方法\"decryption\"请求头部参数,HeadNonce:"+HeadNonce);

    String timestamp = request.getHeader("Wechatpay-Timestamp");// 请求头Wechatpay-Timestamp

    logger.debug("方法\"decryption\"请求头部参数,timestamp:"+timestamp);

    String signature = request.getHeader("Wechatpay-Signature");// 请求头Wechatpay-Signature

    logger.debug("方法\"decryption\"请求头部参数,signature:"+signature);

    String wechatPaySerial = request.getHeader("Wechatpay-Serial");//证书序列号(微信平台)

    logger.debug("方法\"decryption\"请求头部参数,wechatPaySerial:"+wechatPaySerial);

    BufferedReader br = request.getReader();

String str, body = "";//请求主体

while((str = br.readLine()) != null){

body += str;

}

logger.debug("方法\"decryption\"请求主体,body:"+body);

Verifier verifier=wxAppPayConfig.getVerifier();

logger.debug("方法\"decryption\"微信支付证书,verifier:"+verifier);

/*

* 构造一个回调通知请求体,需设置应答平台证书序列号、应答随机串、应答时间戳、应答签名串、应答主体。

*/

        NotificationRequest notifiRequest = new NotificationRequest.Builder().withSerialNumber(wechatPaySerial)

                .withNonce(HeadNonce)

                .withTimestamp(timestamp)

                .withSignature(signature)

                .withBody(body)

                .build();

        logger.debug("方法\"decryption\"构造一个回调通知请求体,notifiRequest:"+notifiRequest);

        /*

         * 使用NotificationHandler构造一个回调通知处理器,需设置验证器、apiV3密钥。调用parse(request)得到回调通知notification。

         */

        NotificationHandler handler = new NotificationHandler(verifier, WxAppPayConfig.apiV3Key.getBytes(StandardCharsets.UTF_8));

        logger.debug("方法\"decryption\"构造一个回调通知处理器,handler:"+handler);

        // 验签和解析请求体

        Notification notification = handler.parse(notifiRequest);

        logger.debug("方法\"decryption\"验签和解析请求体,notification:"+notification);

        Assert.assertNotNull(notification);

        logger.debug("方法\"decryption\"验签和解析");

        //通知资源 数据  json格式,

        Resource resource=notification.getResource();

        logger.debug("方法\"decryption\"通知资源 数据,resource:"+resource);

        String ciphertext=resource.getCiphertext();//数据密文

        logger.debug("方法\"decryption\"数据密文,ciphertext:"+ciphertext);

        String associatedData=resource.getAssociatedData();//附加数据

        logger.debug("方法\"decryption\"附加数据,associatedData:"+associatedData);

        String nonce=resource.getAssociatedData();//加密使用的随机串

        logger.debug("方法\"decryption\"加密使用的随机串,nonce:"+nonce);

        //解密

        final int TAG_LENGTH_BIT = 128;

        Cipher cipher = Cipher.getInstance("AES/GCM/NoPadding");


SecretKeySpec key = new SecretKeySpec(WxAppPayConfig.apiV3Key.getBytes(StandardCharsets.UTF_8), "AES");

GCMParameterSpec spec = new GCMParameterSpec(TAG_LENGTH_BIT, nonce.getBytes(StandardCharsets.UTF_8));

cipher.init(Cipher.DECRYPT_MODE, key, spec);

cipher.updateAAD(associatedData.getBytes(StandardCharsets.UTF_8));

String s=new String(cipher.doFinal(Base64.getDecoder().decode(ciphertext)), "utf-8");

logger.debug("方法\"decryption\"解密之后的josn字符串,str:"+s);

        return JSONObject.parseObject(s);




报错的位置是

// 验签和解析请求体

        Notification notification = handler.parse(notifiRequest);


请问有没有人能解决过这种问题?

回答关注问题邀请回答
收藏

1 个回答

  • 毕设帮
    毕设帮
    2022-11-17

    楼主解决问题了么,我也遇到这个问题了

    2022-11-17
    有用
    回复
登录 后发表内容