我有一个实体,其属性类型为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
我认为我缺少一些代码,但是我无法检测到它;我想我将看到的所有代码都放在了类似的问题中。
答案 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