Странное исключение Джексона возникает при сериализации объекта Hibernate

Джексон выдает странное исключение, которое я не знаю, как исправить. Я использую Spring, Hibernate и Jackson.

Я уже считал, что ленивая загрузка вызывает проблему, но я принял меры, чтобы сказать Джексону НЕ обрабатывать различные свойства следующим образом:

@JsonIgnoreProperties({ "sentMessages", "receivedMessages", "educationFacility" })
public class Director extends UserAccount implements EducationFacilityUser {
   ....
}

Я сделал то же самое вещь для всех других подклассов UserAccount.

Выдается исключение:

org.codehaus.jackson.map.JsonMappingException: No serializer found for class org.hibernate.proxy.pojo.javassist.JavassistLazyInitializer and no properties discovered to create BeanSerializer (to avoid exception, disable SerializationConfig.Feature.FAIL_ON_EMPTY_BEANS) ) (through reference chain: java.util.ArrayList[46]->jobprep.domain.educationfacility.Director_$$_javassist_2["handler"])
    at org.codehaus.jackson.map.ser.StdSerializerProvider$1.serialize(StdSerializerProvider.java:62)
    at org.codehaus.jackson.map.ser.BeanPropertyWriter.serializeAsField(BeanPropertyWriter.java:268)
    at org.codehaus.jackson.map.ser.BeanSerializer.serializeFields(BeanSerializer.java:146)
    at org.codehaus.jackson.map.ser.BeanSerializer.serialize(BeanSerializer.java:118)
    at org.codehaus.jackson.map.ser.ContainerSerializers$IndexedListSerializer.serializeContents(ContainerSerializers.java:236)
    at org.codehaus.jackson.map.ser.ContainerSerializers$IndexedListSerializer.serializeContents(ContainerSerializers.java:189)
    at org.codehaus.jackson.map.ser.ContainerSerializers$AsArraySerializer.serialize(ContainerSerializers.java:111)
    at org.codehaus.jackson.map.ser.StdSerializerProvider._serializeValue(StdSerializerProvider.java:296)
    at org.codehaus.jackson.map.ser.StdSerializerProvider.serializeValue(StdSerializerProvider.java:224)
    at org.codehaus.jackson.map.ObjectMapper.writeValue(ObjectMapper.java:925)
    at org.springframework.http.converter.json.MappingJacksonHttpMessageConverter.writeInternal(MappingJacksonHttpMessageConverter.java:153)

Предложения о том, как я могу получить дополнительную информацию, чтобы узнать, что вызывает это? Кто-нибудь знает, как это исправить?

EDIT: Я обнаружил, что getHander () и другие методы get * () существуют для прокси-объекта. GRR !! Могу ли я как-нибудь сказать Джексону не обрабатывать ничего на прокси-сервере, или я решил? Это действительно странно, потому что метод, выдающий JSON, дает сбой только при определенных обстоятельствах, а не постоянно. Тем не менее, это ' s из-за методов get * () прокси-объекта.

Кроме того: прокси - это зло. Они нарушают работу Jackson, equals () и многие другие части обычного программирования на Java. У меня возникает соблазн вообще отказаться от Hibernate: /

61
задан egervari 6 December 2010 в 00:04
поделиться