如何在春季启动时反序列化/序列化Geometry类型?

时间:2019-07-03 00:50:43

标签: java json spring-boot geometry json-deserialization

我有一个实体,其属性类型为MultiPolygon和Point;所以我正在获取请求,但这返回了SerializationException。

我对其进行了研究,发现我必须做一些说明,创建一个配置类,并将相应的依赖项放入pom.xml中。按照我的操作进行操作:

实体:

package com.zxventures.model;

@Entity
@Table(name = "pdv")
public class PDV implements Serializable {

private static final long serialVersionUID = 1L;

 @Column(name="coverage_area")
 @JsonSerialize(using = GeometrySerializer.class)
 @JsonDeserialize(contentUsing = GeometryDeserializer.class)
 private MultiPolygon coverageArea;

 @Column(name="address")
 @JsonSerialize(using = GeometrySerializer.class)
 @JsonDeserialize(contentUsing = GeometryDeserializer.class)
 private Point address;
}

配置类:

package com.zxventures.config;

@Configuration
public class JacksonConfig {

 @Bean
 public JtsModule jtsModule() {
  return new JtsModule();
 }
}

pom.xml:

<dependency>
<groupId>com.bedatadriven</groupId>
<artifactId>jackson-datatype-jts</artifactId>
<version>2.4</version>
</dependency>

发生异常:

could not deserialize; nested exception is 
org.hibernate.type.SerializationException: could not deserialize

我认为我缺少一些代码,但是我无法检测到它;我想我将看到的所有代码都放在了类似的问题中。

2 个答案:

答案 0 :(得分:1)

我遇到了同样的问题,并在application.properties的下面添加了行,然后它起作用了。

spring.jpa.database-platform=org.hibernate.spatial.dialect.postgis.PostgisDialect

答案 1 :(得分:0)

您正在使用空间数据类型,因此需要添加以下依赖项才能起作用

<dependency>
  <groupId>org.hibernate</groupId>
  <artifactId>hibernate-spatial</artifactId>
</dependency>

并相应地更改方言,例如org.hibernate.spatial.dialect.mysql.MySQL56InnoDBSpatialDialect

请参见Spatial data types