Сделайте Джексон ObjectMapper Сериализуемым - PullRequest
0 голосов
/ 05 марта 2012

Я пытаюсь использовать ObjectMapper Джексона в Wicket. В целом работает, но выдает исключение сериализации: [class=org.codehaus.jackson.map.ObjectMapper] <----- field that is not serializable

Я настраиваю поле с помощью private ObjectMapper mapper = new ObjectMapper();.

Попытка private ObjectMapper mapper = new ObjectMapper().setSerializerProvider(new StdSerializerProvider()); приводит к тому же результату. Я предполагаю, что мне не хватает правильной (комбинации) конфигураций ?! Любые указатели на правильную комбинацию будут высоко оценены.

Полная трассировка стека:

*ERROR:Error serializing object class ....web.backend.overview.OverviewPage [object=[Page class = ....web.backend.overview.OverviewPage, id = 1, render count = 1]]
org.apache.wicket.util.io.SerializableChecker$WicketNotSerializableException: Unable to serialize class: org.codehaus.jackson.map.ObjectMapper
Field hierarchy is:
  1 [class=....web.backend.overview.OverviewPage, path=1]
    private java.lang.Object org.apache.wicket.MarkupContainer.children [class=[Ljava.lang.Object;]
      private org.apache.velocity.app.VelocityEngine ....web.BasePanel.velocityEngine[5] [class=....web.backend.overview.MailBoxQuickOverViewPanel, path=1:mailboxQuickOverviewPanel]
        private java.lang.Object org.apache.wicket.MarkupContainer.children [class=[Ljava.lang.Object;]
          private java.lang.Object org.apache.wicket.MarkupContainer.children[0] [class=....web.backend.overview.ChartPanel, path=1:mailboxQuickOverviewPanel:chartPanel]
            private java.lang.Object org.apache.wicket.MarkupContainer.children [class=com.comsysto.insight.component.HighchartsPanel, path=1:mailboxQuickOverviewPanel:chartPanel:chart]
              private java.lang.Object org.apache.wicket.MarkupContainer.children [class=[Ljava.lang.Object;]
                private java.lang.Object org.apache.wicket.MarkupContainer.children[1] [class=org.apache.wicket.markup.html.basic.Label, path=1:mailboxQuickOverviewPanel:chartPanel:chart:script]
                  java.lang.Object org.apache.wicket.Component.data [class=com.comsysto.insight.component.HighchartsPanel$1]
                    final com.comsysto.insight.model.Highchart com.comsysto.insight.component.HighchartsPanel$1.val$highcharts [class=com.comsysto.insight.model.Highchart]
                      private org.codehaus.jackson.map.ObjectMapper com.comsysto.insight.model.Highchart.mapper [class=org.codehaus.jackson.map.ObjectMapper] <----- field that is not serializable
    at org.apache.wicket.util.io.SerializableChecker.internalCheck(SerializableChecker.java:386) ~[wicket-core-1.5.4.jar:1.5.4]
    at org.apache.wicket.util.io.SerializableChecker.check(SerializableChecker.java:365) ~[wicket-core-1.5.4.jar:1.5.4]
    at org.apache.wicket.util.io.SerializableChecker.checkFields(SerializableChecker.java:646) ~[wicket-core-1.5.4.jar:1.5.4]
    at org.apache.wicket.util.io.SerializableChecker.internalCheck(SerializableChecker.java:569) ~[wicket-core-1.5.4.jar:1.5.4]
    at org.apache.wicket.util.io.SerializableChecker.check(SerializableChecker.java:365) ~[wicket-core-1.5.4.jar:1.5.4]
    at org.apache.wicket.util.io.SerializableChecker.checkFields(SerializableChecker.java:646) ~[wicket-core-1.5.4.jar:1.5.4]
    at org.apache.wicket.util.io.SerializableChecker.internalCheck(SerializableChecker.java:569) ~[wicket-core-1.5.4.jar:1.5.4]
    at org.apache.wicket.util.io.SerializableChecker.check(SerializableChecker.java:365) ~[wicket-core-1.5.4.jar:1.5.4]
    at org.apache.wicket.util.io.SerializableChecker.checkFields(SerializableChecker.java:646) ~[wicket-core-1.5.4.jar:1.5.4]
    at org.apache.wicket.util.io.SerializableChecker.internalCheck(SerializableChecker.java:569) ~[wicket-core-1.5.4.jar:1.5.4]
    at org.apache.wicket.util.io.SerializableChecker.check(SerializableChecker.java:365) ~[wicket-core-1.5.4.jar:1.5.4]
    at org.apache.wicket.util.io.SerializableChecker.internalCheck(SerializableChecker.java:431) ~[wicket-core-1.5.4.jar:1.5.4]
    at org.apache.wicket.util.io.SerializableChecker.check(SerializableChecker.java:365) ~[wicket-core-1.5.4.jar:1.5.4]
    at org.apache.wicket.util.io.SerializableChecker.checkFields(SerializableChecker.java:646) ~[wicket-core-1.5.4.jar:1.5.4]
    at org.apache.wicket.util.io.SerializableChecker.internalCheck(SerializableChecker.java:569) ~[wicket-core-1.5.4.jar:1.5.4]
    at org.apache.wicket.util.io.SerializableChecker.check(SerializableChecker.java:365) ~[wicket-core-1.5.4.jar:1.5.4]
    at org.apache.wicket.util.io.SerializableChecker.checkFields(SerializableChecker.java:646) ~[wicket-core-1.5.4.jar:1.5.4]
    at org.apache.wicket.util.io.SerializableChecker.internalCheck(SerializableChecker.java:569) ~[wicket-core-1.5.4.jar:1.5.4]
    at org.apache.wicket.util.io.SerializableChecker.check(SerializableChecker.java:365) ~[wicket-core-1.5.4.jar:1.5.4]
    at org.apache.wicket.util.io.SerializableChecker.internalCheck(SerializableChecker.java:431) ~[wicket-core-1.5.4.jar:1.5.4]
    at org.apache.wicket.util.io.SerializableChecker.check(SerializableChecker.java:365) ~[wicket-core-1.5.4.jar:1.5.4]
    at org.apache.wicket.util.io.SerializableChecker.checkFields(SerializableChecker.java:646) ~[wicket-core-1.5.4.jar:1.5.4]
    at org.apache.wicket.util.io.SerializableChecker.internalCheck(SerializableChecker.java:569) ~[wicket-core-1.5.4.jar:1.5.4]
    at org.apache.wicket.util.io.SerializableChecker.check(SerializableChecker.java:365) ~[wicket-core-1.5.4.jar:1.5.4]
    at org.apache.wicket.util.io.SerializableChecker.internalCheck(SerializableChecker.java:431) ~[wicket-core-1.5.4.jar:1.5.4]
    at org.apache.wicket.util.io.SerializableChecker.check(SerializableChecker.java:365) ~[wicket-core-1.5.4.jar:1.5.4]
    at org.apache.wicket.util.io.SerializableChecker.checkFields(SerializableChecker.java:646) ~[wicket-core-1.5.4.jar:1.5.4]
    at org.apache.wicket.util.io.SerializableChecker.internalCheck(SerializableChecker.java:569) ~[wicket-core-1.5.4.jar:1.5.4]
    at org.apache.wicket.util.io.SerializableChecker.check(SerializableChecker.java:365) ~[wicket-core-1.5.4.jar:1.5.4]
    at org.apache.wicket.util.io.SerializableChecker.writeObjectOverride(SerializableChecker.java:715) ~[wicket-core-1.5.4.jar:1.5.4]
    at java.io.ObjectOutputStream.writeObject(ObjectOutputStream.java:326) ~[na:1.6.0_29]
    at org.apache.wicket.serialize.java.JavaSerializer$CheckerObjectOutputStream.writeObjectOverride(JavaSerializer.java:258) ~[wicket-core-1.5.4.jar:1.5.4]
    at java.io.ObjectOutputStream.writeObject(ObjectOutputStream.java:326) ~[na:1.6.0_29]
    at org.apache.wicket.serialize.java.JavaSerializer.serialize(JavaSerializer.java:77) ~[wicket-core-1.5.4.jar:1.5.4]
    at org.apache.wicket.pageStore.DefaultPageStore.serializePage(DefaultPageStore.java:368) [wicket-core-1.5.4.jar:1.5.4]
    at org.apache.wicket.pageStore.DefaultPageStore.storePage(DefaultPageStore.java:146) [wicket-core-1.5.4.jar:1.5.4]
    at org.apache.wicket.page.PageStoreManager$PersistentRequestAdapter.storeTouchedPages(PageStoreManager.java:383) [wicket-core-1.5.4.jar:1.5.4]
    at org.apache.wicket.page.RequestAdapter.commitRequest(RequestAdapter.java:171) [wicket-core-1.5.4.jar:1.5.4]
    at org.apache.wicket.page.AbstractPageManager.commitRequest(AbstractPageManager.java:94) [wicket-core-1.5.4.jar:1.5.4]
    at org.apache.wicket.page.PageManagerDecorator.commitRequest(PageManagerDecorator.java:68) [wicket-core-1.5.4.jar:1.5.4]
    at org.apache.wicket.page.PageAccessSynchronizer$2.commitRequest(PageAccessSynchronizer.java:281) [wicket-core-1.5.4.jar:1.5.4]
    at org.apache.wicket.Application$2.onDetach(Application.java:1598) [wicket-core-1.5.4.jar:1.5.4]
    at org.apache.wicket.request.cycle.RequestCycleListenerCollection$3.notify(RequestCycleListenerCollection.java:99) [wicket-core-1.5.4.jar:1.5.4]
    at org.apache.wicket.request.cycle.RequestCycleListenerCollection$3.notify(RequestCycleListenerCollection.java:97) [wicket-core-1.5.4.jar:1.5.4]
    at org.apache.wicket.util.listener.ListenerCollection$1.notify(ListenerCollection.java:119) [wicket-util-1.5.4.jar:1.5.4]
    at org.apache.wicket.util.listener.ListenerCollection.reversedNotify(ListenerCollection.java:143) [wicket-util-1.5.4.jar:1.5.4]
    at org.apache.wicket.util.listener.ListenerCollection.reversedNotifyIgnoringExceptions(ListenerCollection.java:113) [wicket-util-1.5.4.jar:1.5.4]
    at org.apache.wicket.request.cycle.RequestCycleListenerCollection.onDetach(RequestCycleListenerCollection.java:95) [wicket-core-1.5.4.jar:1.5.4]
    at org.apache.wicket.request.cycle.RequestCycle.onDetach(RequestCycle.java:600) [wicket-core-1.5.4.jar:1.5.4]
    at org.apache.wicket.request.cycle.RequestCycle.detach(RequestCycle.java:539) [wicket-core-1.5.4.jar:1.5.4]
    at org.apache.wicket.request.cycle.RequestCycle.processRequestAndDetach(RequestCycle.java:287) [wicket-core-1.5.4.jar:1.5.4]
    at org.apache.wicket.protocol.http.WicketFilter.processRequest(WicketFilter.java:162) [wicket-core-1.5.4.jar:1.5.4]
    at org.apache.wicket.protocol.http.WicketFilter.doFilter(WicketFilter.java:218) [wicket-core-1.5.4.jar:1.5.4]
    at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:243) [catalina.jar:7.0.25]
    at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:210) [catalina.jar:7.0.25]
    at org.apache.shiro.web.servlet.AbstractShiroFilter.executeChain(AbstractShiroFilter.java:359) [shiro-web-1.1.0.jar:na]
    at org.apache.shiro.web.servlet.AbstractShiroFilter$1.call(AbstractShiroFilter.java:275) [shiro-web-1.1.0.jar:na]
    at org.apache.shiro.subject.support.SubjectCallable.doCall(SubjectCallable.java:90) [shiro-core-1.1.0.jar:1.1.0]
    at org.apache.shiro.subject.support.SubjectCallable.call(SubjectCallable.java:83) [shiro-core-1.1.0.jar:1.1.0]
    at org.apache.shiro.subject.support.DelegatingSubject.execute(DelegatingSubject.java:344) [shiro-core-1.1.0.jar:1.1.0]
    at org.apache.shiro.web.servlet.AbstractShiroFilter.doFilterInternal(AbstractShiroFilter.java:272) [shiro-web-1.1.0.jar:na]
    at org.apache.shiro.web.servlet.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:81) [shiro-web-1.1.0.jar:na]
    at org.springframework.web.filter.DelegatingFilterProxy.invokeDelegate(DelegatingFilterProxy.java:346) [spring-web-3.1.0.RELEASE.jar:3.1.0.RELEASE]
    at org.springframework.web.filter.DelegatingFilterProxy.doFilter(DelegatingFilterProxy.java:259) [spring-web-3.1.0.RELEASE.jar:3.1.0.RELEASE]
    at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:243) [catalina.jar:7.0.25]
    at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:210) [catalina.jar:7.0.25]
    at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:224) [catalina.jar:7.0.25]
    at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:169) [catalina.jar:7.0.25]
    at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:472) [catalina.jar:7.0.25]
    at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:168) [catalina.jar:7.0.25]
    at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:98) [catalina.jar:7.0.25]
    at org.apache.catalina.valves.AccessLogValve.invoke(AccessLogValve.java:927) [catalina.jar:7.0.25]
    at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:118) [catalina.jar:7.0.25]
    at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:407) [catalina.jar:7.0.25]
    at org.apache.coyote.http11.AbstractHttp11Processor.process(AbstractHttp11Processor.java:987) [tomcat-coyote.jar:7.0.25]
    at org.apache.coyote.AbstractProtocol$AbstractConnectionHandler.process(AbstractProtocol.java:579) [tomcat-coyote.jar:7.0.25]
    at org.apache.tomcat.util.net.JIoEndpoint$SocketProcessor.run(JIoEndpoint.java:309) [tomcat-coyote.jar:7.0.25]
    at java.util.concurrent.ThreadPoolExecutor$Worker.runTask(ThreadPoolExecutor.java:886) [na:1.6.0_29]
    at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:908) [na:1.6.0_29]
    at java.lang.Thread.run(Thread.java:680) [na:1.6.0_29]
Caused by: java.io.NotSerializableException: org.codehaus.jackson.map.ObjectMapper
    at java.io.ObjectOutputStream.writeObject0(ObjectOutputStream.java:1164) ~[na:1.6.0_29]
    at java.io.ObjectOutputStream.defaultWriteFields(ObjectOutputStream.java:1518) ~[na:1.6.0_29]
    at java.io.ObjectOutputStream.writeSerialData(ObjectOutputStream.java:1483) ~[na:1.6.0_29]
    at java.io.ObjectOutputStream.writeOrdinaryObject(ObjectOutputStream.java:1400) ~[na:1.6.0_29]
    at java.io.ObjectOutputStream.writeObject0(ObjectOutputStream.java:1158) ~[na:1.6.0_29]
    at java.io.ObjectOutputStream.defaultWriteFields(ObjectOutputStream.java:1518) ~[na:1.6.0_29]
    at java.io.ObjectOutputStream.writeSerialData(ObjectOutputStream.java:1483) ~[na:1.6.0_29]
    at java.io.ObjectOutputStream.writeOrdinaryObject(ObjectOutputStream.java:1400) ~[na:1.6.0_29]
    at java.io.ObjectOutputStream.writeObject0(ObjectOutputStream.java:1158) ~[na:1.6.0_29]
    at java.io.ObjectOutputStream.defaultWriteFields(ObjectOutputStream.java:1518) ~[na:1.6.0_29]
    at java.io.ObjectOutputStream.writeSerialData(ObjectOutputStream.java:1483) ~[na:1.6.0_29]
    at java.io.ObjectOutputStream.writeOrdinaryObject(ObjectOutputStream.java:1400) ~[na:1.6.0_29]
    at java.io.ObjectOutputStream.writeObject0(ObjectOutputStream.java:1158) ~[na:1.6.0_29]
    at java.io.ObjectOutputStream.writeArray(ObjectOutputStream.java:1346) ~[na:1.6.0_29]
    at java.io.ObjectOutputStream.writeObject0(ObjectOutputStream.java:1154) ~[na:1.6.0_29]
    at java.io.ObjectOutputStream.defaultWriteFields(ObjectOutputStream.java:1518) ~[na:1.6.0_29]
    at java.io.ObjectOutputStream.writeSerialData(ObjectOutputStream.java:1483) ~[na:1.6.0_29]
    at java.io.ObjectOutputStream.writeOrdinaryObject(ObjectOutputStream.java:1400) ~[na:1.6.0_29]
    at java.io.ObjectOutputStream.writeObject0(ObjectOutputStream.java:1158) ~[na:1.6.0_29]
    at java.io.ObjectOutputStream.defaultWriteFields(ObjectOutputStream.java:1518) ~[na:1.6.0_29]
    at java.io.ObjectOutputStream.writeSerialData(ObjectOutputStream.java:1483) ~[na:1.6.0_29]
    at java.io.ObjectOutputStream.writeOrdinaryObject(ObjectOutputStream.java:1400) ~[na:1.6.0_29]
    at java.io.ObjectOutputStream.writeObject0(ObjectOutputStream.java:1158) ~[na:1.6.0_29]
    at java.io.ObjectOutputStream.writeArray(ObjectOutputStream.java:1346) ~[na:1.6.0_29]
    at java.io.ObjectOutputStream.writeObject0(ObjectOutputStream.java:1154) ~[na:1.6.0_29]
    at java.io.ObjectOutputStream.defaultWriteFields(ObjectOutputStream.java:1518) ~[na:1.6.0_29]
    at java.io.ObjectOutputStream.writeSerialData(ObjectOutputStream.java:1483) ~[na:1.6.0_29]
    at java.io.ObjectOutputStream.writeOrdinaryObject(ObjectOutputStream.java:1400) ~[na:1.6.0_29]
    at java.io.ObjectOutputStream.writeObject0(ObjectOutputStream.java:1158) ~[na:1.6.0_29]
    at java.io.ObjectOutputStream.writeArray(ObjectOutputStream.java:1346) ~[na:1.6.0_29]
    at java.io.ObjectOutputStream.writeObject0(ObjectOutputStream.java:1154) ~[na:1.6.0_29]
    at java.io.ObjectOutputStream.defaultWriteFields(ObjectOutputStream.java:1518) ~[na:1.6.0_29]
    at java.io.ObjectOutputStream.writeSerialData(ObjectOutputStream.java:1483) ~[na:1.6.0_29]
    at java.io.ObjectOutputStream.writeOrdinaryObject(ObjectOutputStream.java:1400) ~[na:1.6.0_29]
    at java.io.ObjectOutputStream.writeObject0(ObjectOutputStream.java:1158) ~[na:1.6.0_29]
    at java.io.ObjectOutputStream.writeObject(ObjectOutputStream.java:330) ~[na:1.6.0_29]
    at org.apache.wicket.serialize.java.JavaSerializer$CheckerObjectOutputStream.writeObjectOverride(JavaSerializer.java:250) ~[wicket-core-1.5.4.jar:1.5.4]
    ... 48 common frames omitted

1 Ответ

3 голосов
/ 05 марта 2012

ObjectMapper не должно быть сериализовано.Это не Serializable, и по уважительной причине.

Таким образом, у вас есть некоторые другие проблемы, связанные с вашим использованием: как указывали другие, нет никаких причин, по которым сериализуемость или ее отсутствие ObjectMapper должны вызывать проблемы.Скорее всего, у вас случайно есть зависимости от Mapper или что-то подобное: удалите эти зависимости.Доступ к мапперам обычно осуществляется как статические синглтоны (что нормально), или вводится с использованием чего-то вроде Guice или Spring IoC.

Исходя из исходного вопроса, вам, вероятно, следует просто создать статический экземпляр ObjectMapper -очень важно НЕ создавать новый экземпляр для каждого запроса, а использовать повторно экземпляр (ы).

РЕДАКТИРОВАТЬ (2013/10): как указано @Jason, ObjectMapper, это больше не правда.Оказывается, есть одна потенциальная причина, когда используется на некоторых платформах - например, на Android, способность «заморозить» маппер может быть выигрыш в производительности.Я бы не рекомендовал ее в качестве стратегии по умолчанию, но, по крайней мере, это вариант.

...