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