2017-06-20 4 views
0

私はREST APIにJersey-Spring4を使用しています。 これは私が持っている、関連のpom.xmlセクションです:JerseyとJacksonで直列化(遅延読み込み)エンティティ

<properties> 
     <jersey.version>2.25.1</jersey.version> 
     <guava.version>19.0</guava.version> 
     <jackson.version>2.25.1</jackson.version> 
     <slf4j.version>1.7.12</slf4j.version> 
     <logback.version>1.1.3</logback.version> 
     <antisamy.version>1.5.3</antisamy.version> 
     <spring.version>4.3.7.RELEASE</spring.version> 
     <junit.version>4.12</junit.version> 
    </properties> 

    <dependencies> 
     <dependency> 
      <groupId>com.openkm</groupId> 
      <artifactId>sdk4j</artifactId> 
      <version>2.3</version> 
     </dependency> 

     <!-- Servlet --> 
     <dependency> 
      <groupId>javax.servlet</groupId> 
      <artifactId>javax.servlet-api</artifactId> 
      <version>3.1.0</version> 
      <scope>provided</scope> 
     </dependency> 

     <!-- JAX-RS --> 
     <dependency> 
      <groupId>javax.ws.rs</groupId> 
      <artifactId>javax.ws.rs-api</artifactId> 
      <version>2.0.1</version> 
      <scope>compile</scope> 
     </dependency> 

     <!-- Jersey --> 
     <dependency> 
      <groupId>org.glassfish.jersey.containers</groupId> 
      <artifactId>jersey-container-servlet</artifactId> 
      <version>${jersey.version}</version> 
     </dependency> 
     <dependency> 
      <groupId>org.glassfish.jersey.core</groupId> 
      <artifactId>jersey-server</artifactId> 
      <version>${jersey.version}</version> 
     </dependency> 
     <dependency> 
      <groupId>org.glassfish.jersey.media</groupId> 
      <artifactId>jersey-media-json-jackson</artifactId> 
      <version>${jersey.version}</version> 
     </dependency> 
     <dependency> 
      <groupId>org.glassfish.jersey.media</groupId> 
      <artifactId>jersey-media-multipart</artifactId> 
      <version>${jersey.version}</version> 
     </dependency> 
     <dependency> 
      <groupId>org.glassfish.jersey.ext</groupId> 
      <artifactId>jersey-bean-validation</artifactId> 
      <version>${jersey.version}</version> 
     </dependency> 

     <!-- 
Note: There is a bug of jersey-spring3 -> https://java.net/jira/browse/JERSEY-2038 
--> 
     <dependency> 
      <groupId>org.glassfish.jersey.ext</groupId> 
      <artifactId>jersey-spring3</artifactId> 
      <version>${jersey.version}</version> 
      <exclusions> 
       <exclusion> 
        <artifactId>spring-context</artifactId> 
        <groupId>org.springframework</groupId> 
       </exclusion> 
       <exclusion> 
        <artifactId>spring-beans</artifactId> 
        <groupId>org.springframework</groupId> 
       </exclusion> 
       <exclusion> 
        <artifactId>spring-core</artifactId> 
        <groupId>org.springframework</groupId> 
       </exclusion> 
       <exclusion> 
        <artifactId>spring-web</artifactId> 
        <groupId>org.springframework</groupId> 
       </exclusion> 
       <exclusion> 
        <artifactId>jersey-server</artifactId> 
        <groupId>org.glassfish.jersey.core</groupId> 
       </exclusion> 
       <exclusion> 
        <artifactId> 
         jersey-container-servlet-core 
        </artifactId> 
        <groupId>org.glassfish.jersey.containers</groupId> 
       </exclusion> 
       <exclusion> 
        <artifactId>hk2</artifactId> 
        <groupId>org.glassfish.hk2</groupId> 
       </exclusion> 
      </exclusions> 
     </dependency> 

     <!-- Spring --> 
     <dependency> 
      <groupId>org.springframework</groupId> 
      <artifactId>spring-context</artifactId> 
      <version>${spring.version}</version> 
      <exclusions> 
       <exclusion> 
        <groupId>commons-logging</groupId> 
        <artifactId>commons-logging</artifactId> 
       </exclusion> 
      </exclusions> 
     </dependency> 
     <dependency> 
      <groupId>org.springframework</groupId> 
      <artifactId>spring-beans</artifactId> 
      <version>${spring.version}</version> 
     </dependency> 
     <dependency> 
      <groupId>org.springframework</groupId> 
      <artifactId>spring-web</artifactId> 
      <version>${spring.version}</version> 
     </dependency> 
     <dependency> 
      <groupId>org.springframework</groupId> 
      <artifactId>spring-aop</artifactId> 
      <version>${spring.version}</version> 
     </dependency> 
     <dependency> 
      <groupId>org.springframework</groupId> 
      <artifactId>spring-core</artifactId> 
      <version>${spring.version}</version> 
      <exclusions> 
       <exclusion> 
        <groupId>commons-logging</groupId> 
        <artifactId>commons-logging</artifactId> 
       </exclusion> 
      </exclusions> 
     </dependency> 
     <dependency> 
      <groupId>org.springframework</groupId> 
      <artifactId>spring-tx</artifactId> 
      <version>${spring.version}</version> 
     </dependency> 
     <dependency> 
      <groupId>org.springframework</groupId> 
      <artifactId>spring-orm</artifactId> 
      <version>${spring.version}</version> 
     </dependency> 
     <dependency> 
      <groupId>org.springframework.data</groupId> 
      <artifactId>spring-data-jpa</artifactId> 
      <version>1.11.1.RELEASE</version> 
     </dependency> 
     <dependency> 
      <groupId>org.springframework</groupId> 
      <artifactId>spring-aspects</artifactId> 
      <version>4.3.5.RELEASE</version> 
     </dependency> 

     <!-- Google Guava --> 
     <dependency> 
      <groupId>com.google.guava</groupId> 
      <artifactId>guava</artifactId> 
      <version>${guava.version}</version> 
     </dependency> 
     <!-- logging --> 
     <dependency> 
      <groupId>org.slf4j</groupId> 
      <artifactId>slf4j-api</artifactId> 
      <version>${slf4j.version}</version> 
     </dependency> 
     <dependency> 
      <groupId>org.slf4j</groupId> 
      <artifactId>jcl-over-slf4j</artifactId> 
      <version>${slf4j.version}</version> 
     </dependency> 
     <dependency> 
      <groupId>ch.qos.logback</groupId> 
      <artifactId>logback-core</artifactId> 
      <version>${logback.version}</version> 
     </dependency> 
     <dependency> 
      <groupId>ch.qos.logback</groupId> 
      <artifactId>logback-classic</artifactId> 
      <version>${logback.version}</version> 
     </dependency> 
     <dependency> 
      <groupId>org.owasp.antisamy</groupId> 
      <artifactId>antisamy</artifactId> 
      <version>${antisamy.version}</version> 
     </dependency> 

     <!-- Apache HTTP Client --> 
     <dependency> 
      <groupId>org.apache.httpcomponents</groupId> 
      <artifactId>httpclient</artifactId> 
      <version>4.5.1</version> 
     </dependency> 
     <dependency> 
      <groupId>org.apache.httpcomponents</groupId> 
      <artifactId>fluent-hc</artifactId> 
      <version>4.5.1</version> 
     </dependency> 
     <dependency> 
      <groupId>org.apache.httpcomponents</groupId> 
      <artifactId>httpmime</artifactId> 
      <version>4.5.2</version> 
     </dependency> 

     <dependency> 
      <groupId>org.hibernate</groupId> 
      <artifactId>hibernate-core</artifactId> 
      <version>5.2.9.Final</version> 
     </dependency> 

     <dependency> 
      <groupId>org.hibernate.javax.persistence</groupId> 
      <artifactId>hibernate-jpa-2.1-api</artifactId> 
      <version>1.0.0.Final</version> 
     </dependency> 

     <dependency> 
      <groupId>org.hibernate</groupId> 
      <artifactId>hibernate-envers</artifactId> 
      <version>5.2.9.Final</version> 
     </dependency> 

     <dependency> 
      <groupId>com.fasterxml.jackson.datatype</groupId> 
      <artifactId>jackson-datatype-hibernate5</artifactId> 
      <version>2.8.4</version> 
     </dependency> 

     <dependency> 
      <groupId>org.postgresql</groupId> 
      <artifactId>postgresql</artifactId> 
      <version>42.0.0</version> 
     </dependency> 

     <dependency> 
      <groupId>javax.inject</groupId> 
      <artifactId>javax.inject</artifactId> 
      <version>1</version> 
     </dependency> 

     <!-- Test --> 
     <dependency> 
      <groupId>junit</groupId> 
      <artifactId>junit</artifactId> 
      <version>${junit.version}</version> 
      <scope>test</scope> 
     </dependency> 
     <dependency> 
      <groupId>org.hamcrest</groupId> 
      <artifactId>hamcrest-library</artifactId> 
      <version>1.3</version> 
      <scope>test</scope> 
     </dependency> 
     <dependency> 
      <groupId>org.springframework</groupId> 
      <artifactId>spring-test</artifactId> 
      <version>${spring.version}</version> 
      <scope>test</scope> 
     </dependency> 
     <dependency> 
      <groupId>commons-lang</groupId> 
      <artifactId>commons-lang</artifactId> 
      <version>2.6</version> 
     </dependency> 

     <!-- Swagger dependencies --> 
     <dependency> 
      <groupId>io.swagger</groupId> 
      <artifactId>swagger-jersey2-jaxrs</artifactId> 
      <scope>compile</scope> 
      <version>1.5.13</version> 
     </dependency> 

     <dependency> 
      <groupId>com.nimbusds</groupId> 
      <artifactId>nimbus-jose-jwt</artifactId> 
      <version>4.0</version> 
     </dependency> 

     <dependency> 
      <groupId>joda-time</groupId> 
      <artifactId>joda-time</artifactId> 
      <version>2.9.9</version> 
     </dependency> 

    </dependencies> 

、これは私がプロジェクトの設定方法:

@Configuration("appConfig") 
@ComponentScan(value = "com.nws.vedica", lazyInit = true) 
@PropertySource({"classpath:swagger.properties", "classpath:vedica.properties"}) 
@ApplicationPath("/api") 
@EnableJpaAuditing(auditorAwareRef="auditorProvider") 
public class VedicaConfig extends ResourceConfig { 

public VedicaConfig() { 
    packages("com.nws.vedica"); 
    property(ServletProperties.FILTER_FORWARD_ON_404, true); 
    register(MultiPartFeature.class); 
    register(JacksonFeature.class); 
//  register(MOXyJsonProvider.class); 
     register(ValidationFeature.class); 
     register(ValidationConfigurationContextResolver.class); 
     register(PropertySourcesPlaceholderConfigurer.class); 

    register(ApiListingResource.class); 
    register(SwaggerSerializers.class); 
} 

@Bean 
AuditorAware<String> auditorProvider() { 
    return new AuditorAware<String>() { 
     @Override 
     public String getCurrentAuditor() { 
      return "qwer"; 
     } 
    }; 
} 

@Bean 
public PersistenceExceptionTranslationPostProcessor exceptionTranslation() { 
    return new PersistenceExceptionTranslationPostProcessor(); 
} 
} 

を今、私の大きな、迷惑な、問題は、私はそのエンティティを返すときということですそこに怠け者を取り込むエンティティがあります。WARNING: com.fasterxml.jackson.databind.JsonMappingException: (was java.lang.NullPointerException) (through reference chain: com.nws.vedica.model.entity.PartyKind["doc2"]->com.nws.vedica.model.entity.Document2["docType"]->com.nws.vedica.model.entity.DocType["validityRule"]->com.nws.vedica.model.entity.ValidityRule["validFrom"]) 例外があります。

オーケー、私は多くの記事と私はジャクソン(すべてFetchType.EAGERである私のエンティティを初期化するために

<dependency> 
     <groupId>com.fasterxml.jackson.datatype</groupId> 
     <artifactId>jackson-datatype-hibernate5</artifactId> 
     <version>2.8.4</version> 
    </dependency> 

パッケージを使用する必要が私に言ったスレッドを経て、私は本当に分からない理由これは起こっている)。

だから私はjackson-datatype-hibernate5依存関係を追加し、以下のように設定して、それを登録するとき:

@Bean 
public Module datatypeHibernateModule() { 
    return new Hibernate5Module(); 
} 

しかし、私はまだ同じ例外を取得しています。私の意見では、ジャージーのために異なるdatatype-hibernate5 hibernateパッケージが必要だが、見つけられないということです。別の方法で登録してください。

この作品を作成する方法をアドバイスできますか? ありがとう

答えて

0

あなたはSpring Bootを使用しているようには見えません。 Spring BeanとしてのModuleは、Spring Bootでのみ動作するものです。 Jerseyでジャクソンを設定する場合は、ContextResolverを使用してObjectMapperを設定する必要があります。その後

@Provider 
public class ObjectMapperContextResolver implements ContextResolver<ObjectMapper> { 

    private final ObjectMapper mapper; 

    public ObjectMapperContextResolver() { 
     mapper = new ObjectMapper(); 
     mapper.registerModule(new Hibernate5Module()); 
    } 

    @Override 
    public ObjectMapper getContext(Class<?> type) { 
     return mapper; 
    } 
} 

、おかげで問題を解決ジャージー

register(ObjectMapperContextResolver.class); 
+0

うん、とそれを登録! – greengold

+0

これは昨日働いていましたが、今日、同じエラーでシリアル化が失敗します。私はFetchType.LAZYを持っているとすぐにプロキシを持ち、Hibernate.initialize()は動作しません。しかし、私は '実体が現実化されました'か、それとも...ここで何が問題になるのか分かりますか?それはちょうど私が熱心なローディングを設定したときに動作します... – greengold

+0

ええ、私は本当に確実ではありません。 –

関連する問題