微信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); 请问有没有人能解决过这种问题?