com.fasterxml.jackson.databind.JsonMappingException: No serializer found for class org.apache.ibati
来源:互联网 发布:天猫盒子有线网络设置 编辑:程序博客网 时间:2024/05/21 19:25
开始查询数据库的结果是A类的一个list,然后在代码Java里面将List<A> 的数据结构改为List<B>,B类里面又包含List<A>的一个属性。后面将其改为直接从数据库里面将List<B>查询出来,不在代码里面做转换了,不知道有没有解释清楚,先贴报错:
2017-11-15 11:16:49 302739 [http-nio-5014-exec-3] ERROR c.s.b.e.h.CommonExceptionHandler - 产生异常 org.springframework.http.converter.HttpMessageNotWritableException: Could not write content: No serializer found for class org.apache.ibatis.executor.loader.javassist.JavassistProxyFactory$EnhancedResultObjectProxyImpl and no properties discovered to create BeanSerializer (to avoid exception, disable SerializationFeature.FAIL_ON_EMPTY_BEANS) (through reference chain: com.snfq.base.dto.ResultDTO["result"]->com.snfq.base.dto.PageDTO["list"]->com.github.pagehelper.Page[0]->com.snfq.withholdmiddleware.dto.response.BankChnlResponse_$$_jvstef7_0["handler"]); nested exception is com.fasterxml.jackson.databind.JsonMappingException: No serializer found for class org.apache.ibatis.executor.loader.javassist.JavassistProxyFactory$EnhancedResultObjectProxyImpl and no properties discovered to create BeanSerializer (to avoid exception, disable SerializationFeature.FAIL_ON_EMPTY_BEANS) (through reference chain: com.snfq.base.dto.ResultDTO["result"]->com.snfq.base.dto.PageDTO["list"]->com.github.pagehelper.Page[0]->com.snfq.withholdmiddleware.dto.response.BankChnlResponse_$$_jvstef7_0["handler"])at org.springframework.http.converter.json.AbstractJackson2HttpMessageConverter.writeInternal(AbstractJackson2HttpMessageConverter.java:292)at org.springframework.http.converter.AbstractGenericHttpMessageConverter.write(AbstractGenericHttpMessageConverter.java:100)at org.springframework.web.servlet.mvc.method.annotation.AbstractMessageConverterMethodProcessor.writeWithMessageConverters(AbstractMessageConverterMethodProcessor.java:231)at org.springframework.web.servlet.mvc.method.annotation.RequestResponseBodyMethodProcessor.handleReturnValue(RequestResponseBodyMethodProcessor.java:174)at org.springframework.web.method.support.HandlerMethodReturnValueHandlerComposite.handleReturnValue(HandlerMethodReturnValueHandlerComposite.java:81)at org.springframework.web.servlet.mvc.method.annotation.ServletInvocableHandlerMethod.invokeAndHandle(ServletInvocableHandlerMethod.java:132)at org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter.invokeHandlerMethod(RequestMappingHandlerAdapter.java:827)at org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter.handleInternal(RequestMappingHandlerAdapter.java:738)at org.springframework.web.servlet.mvc.method.AbstractHandlerMethodAdapter.handle(AbstractHandlerMethodAdapter.java:85)at org.springframework.web.servlet.DispatcherServlet.doDispatch(DispatcherServlet.java:963)at org.springframework.web.servlet.DispatcherServlet.doService(DispatcherServlet.java:897)at org.springframework.web.servlet.FrameworkServlet.processRequest(FrameworkServlet.java:970)at org.springframework.web.servlet.FrameworkServlet.doGet(FrameworkServlet.java:861)at javax.servlet.http.HttpServlet.service(HttpServlet.java:622)at org.springframework.web.servlet.FrameworkServlet.service(FrameworkServlet.java:846)at javax.servlet.http.HttpServlet.service(HttpServlet.java:729)at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:230)at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:165)at org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:52)at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:192)at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:165)at org.springframework.boot.web.filter.ApplicationContextHeaderFilter.doFilterInternal(ApplicationContextHeaderFilter.java:55)at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:107)at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:192)at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:165)at com.alibaba.druid.support.http.WebStatFilter.doFilter(WebStatFilter.java:123)at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:192)at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:165)at org.springframework.boot.actuate.trace.WebRequestTraceFilter.doFilterInternal(WebRequestTraceFilter.java:108)at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:107)at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:192)at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:165)at com.snfq.base.auth.filter.SubjectFilter.doFilterInternal(SubjectFilter.java:48)at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:107)at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:192)at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:165)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:192)at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:165)at org.springframework.web.filter.HttpPutFormContentFilter.doFilterInternal(HttpPutFormContentFilter.java:105)at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:107)at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:192)at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:165)at org.springframework.web.filter.HiddenHttpMethodFilter.doFilterInternal(HiddenHttpMethodFilter.java:81)at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:107)at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:192)at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:165)at org.springframework.web.filter.CharacterEncodingFilter.doFilterInternal(CharacterEncodingFilter.java:197)at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:107)at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:192)at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:165)at org.springframework.boot.actuate.autoconfigure.MetricsFilter.doFilterInternal(MetricsFilter.java:106)at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:107)at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:192)at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:165)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:474)at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:140)at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:79)at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:87)at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:349)at org.apache.coyote.http11.Http11Processor.service(Http11Processor.java:783)at org.apache.coyote.AbstractProcessorLight.process(AbstractProcessorLight.java:66)at org.apache.coyote.AbstractProtocol$ConnectionHandler.process(AbstractProtocol.java:798)at org.apache.tomcat.util.net.NioEndpoint$SocketProcessor.doRun(NioEndpoint.java:1434)at org.apache.tomcat.util.net.SocketProcessorBase.run(SocketProcessorBase.java:49)at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1142)at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:617)at org.apache.tomcat.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:61)at java.lang.Thread.run(Thread.java:745)Caused by: com.fasterxml.jackson.databind.JsonMappingException: No serializer found for class org.apache.ibatis.executor.loader.javassist.JavassistProxyFactory$EnhancedResultObjectProxyImpl and no properties discovered to create BeanSerializer (to avoid exception, disable SerializationFeature.FAIL_ON_EMPTY_BEANS) (through reference chain: com.snfq.base.dto.ResultDTO["result"]->com.snfq.base.dto.PageDTO["list"]->com.github.pagehelper.Page[0]->com.snfq.withholdmiddleware.dto.response.BankChnlResponse_$$_jvstef7_0["handler"])at com.fasterxml.jackson.databind.JsonMappingException.from(JsonMappingException.java:284)at com.fasterxml.jackson.databind.SerializerProvider.mappingException(SerializerProvider.java:1110)at com.fasterxml.jackson.databind.SerializerProvider.reportMappingProblem(SerializerProvider.java:1135)at com.fasterxml.jackson.databind.ser.impl.UnknownSerializer.failForEmpty(UnknownSerializer.java:69)at com.fasterxml.jackson.databind.ser.impl.UnknownSerializer.serialize(UnknownSerializer.java:32)at com.fasterxml.jackson.databind.ser.BeanPropertyWriter.serializeAsField(BeanPropertyWriter.java:704)at com.fasterxml.jackson.databind.ser.std.BeanSerializerBase.serializeFields(BeanSerializerBase.java:690)at com.fasterxml.jackson.databind.ser.BeanSerializer.serialize(BeanSerializer.java:155)at com.fasterxml.jackson.databind.ser.impl.IndexedListSerializer.serializeContents(IndexedListSerializer.java:119)at com.fasterxml.jackson.databind.ser.impl.IndexedListSerializer.serialize(IndexedListSerializer.java:79)at com.fasterxml.jackson.databind.ser.impl.IndexedListSerializer.serialize(IndexedListSerializer.java:18)at com.fasterxml.jackson.databind.ser.BeanPropertyWriter.serializeAsField(BeanPropertyWriter.java:704)at com.fasterxml.jackson.databind.ser.std.BeanSerializerBase.serializeFields(BeanSerializerBase.java:690)at com.fasterxml.jackson.databind.ser.BeanSerializer.serialize(BeanSerializer.java:155)at com.fasterxml.jackson.databind.ser.BeanPropertyWriter.serializeAsField(BeanPropertyWriter.java:704)at com.fasterxml.jackson.databind.ser.std.BeanSerializerBase.serializeFields(BeanSerializerBase.java:690)at com.fasterxml.jackson.databind.ser.BeanSerializer.serialize(BeanSerializer.java:155)at com.fasterxml.jackson.databind.ser.DefaultSerializerProvider.serializeValue(DefaultSerializerProvider.java:292)at com.fasterxml.jackson.databind.ObjectWriter$Prefetch.serialize(ObjectWriter.java:1429)at com.fasterxml.jackson.databind.ObjectWriter.writeValue(ObjectWriter.java:951)at org.springframework.http.converter.json.AbstractJackson2HttpMessageConverter.writeInternal(AbstractJackson2HttpMessageConverter.java:285)... 71 common frames omitted
然后贴一下报错相关的类,
首先是BankChnlResponse类,也就是上面提到的类B:
public class BankChnlResponse implements Serializable { private static final long serialVersionUID = 1L; /** 修改人 */ private String editor; /** 修改时间 */ private Date gmtModified; /** 银行编码 */ private String bankCode; /** 银行名称 */ private String bankName; /** 银行渠道响应对象list */ private List<ChnlSpBankInfo> list;}然后就是ChnlSpBankInfo类,即上面提到的类A:
public class ChnlSpBankInfo implements Serializable { private static final long serialVersionUID = 1L; /** 主键ID */ private String id; /** 银行编码 */ private String bankCode; /** 渠道编码 */ private String channelCode; /** 银行名称 */ private String bankName; /** 渠道名称 */ private String channelName; /** 渠道优先级 */ private Integer priority;}
后面百度参考了文章:http://godfox.iteye.com/blog/646887
大概理解了,然后根据错误找了一下原因,DEBUG发现确实是因为在运行时BankChnlResponse类多出了一个属性,也就是报错中的"handler",不过不是很清楚为什么。
于是在BankChnlResponse类上加了:
@JsonIgnoreProperties(value = { "handler" })问题解决~
阅读全文
0 0
- com.fasterxml.jackson.databind.JsonMappingException: No serializer found for class org.apache.ibati
- com.fasterxml.jackson.databind.JsonMappingException: No serializer found for class ...
- com.fasterxml.jackson.databind.JsonMappingException: No serializer found for
- org.codehaus.jackson.map.JsonMappingException: No serializer found for class
- com.fasterxml.jackson.databind.JsonMappingException:No suitable constructor found for type
- org.codehaus.jackson.map.JsonMappingException: No serializer found for class org.hibernate.proxy....
- 【jackson 异常】com.fasterxml.jackson.databind.JsonMappingException异常处理
- zeppelin spark interpreter异常 com.fasterxml.jackson.databind.JsonMappingException
- 解决com.fasterxml.jackson.databind.JsonMappingException: No suitable 以 Jackson 处理复杂类型(List,map)两种方法
- JackSon将json串转成List<Object>,异常com.fasterxml.jackson.databind.JsonMappingException
- 使用WebService报:No serializer found for class ××× in registry org.apache.axis.encoding.TypeMappingDele
- json异常com.fasterxml.jackson.databind.JsonMappingException: Can not instantiate value of type #657
- nested exception is com.fasterxml.jackson.databind.JsonMappingException: Conflicting getter definiti
- com.fasterxml.jackson.databind.JsonMappingException: Can not deserialize out of START_ARRAY token
- org.codehaus.jackson.map.JsonMappingException: No suitable constructor found for type [si
- jackson.databind之 com.fasterxml.jackson.databind.ser...错误
- com.fasterxml.jackson.databind.exc.MismatchedInputException
- com.fasterxml.jackson.databind.exc.UnrecognizedPropertyException
- Terrorists UVALive
- hdu3829-Cat VS Dog(最大独立集,匹配问题)
- sed
- Vue学习日志:Vue实例(2)
- angularjs中的filter(过滤器)——格式化日期的date
- com.fasterxml.jackson.databind.JsonMappingException: No serializer found for class org.apache.ibati
- 使用PullToRefresh实现下拉刷新和上拉加载
- Mac小技巧之Sierra系统中安全性与隐私中没有"任何来源"选项
- Gson 解析集合泛型
- 言论 | 面对机器人上岗,白领比蓝领更容易丢饭碗?
- 前沿 | 复活逝者?他在用聊天机器人复制一个自己
- mysql-1045 28000错误/mysql解决root账户密码丢失 ubuntu系统
- xshell终端中文乱码完全解决方法
- 预言 | 谷歌AI专家预测:未来20年机器与人脑将合而为一