Java PostgreSQL:遇到无效的endian标志值

Java PostgreSQL:遇到无效的endian标志值,java,postgresql,geospatial,Java,Postgresql,Geospatial,我试图建立一个包含一些地理空间数据的PostreSQL表,并进行一些空间查询。但我遇到了“遇到无效的endian标志值”错误。 我一直在互联网上寻找解决方案,但到目前为止还没有一个解决方案。没有主意了。我需要帮助 情况就是这样 实体类: import com.vividsolutions.jts.geom.Point; import com.vividsolutions.jts.geom.Geometry; import com.vividsolutions.jts.geom.LineStrin

我试图建立一个包含一些地理空间数据的PostreSQL表,并进行一些空间查询。但我遇到了“遇到无效的endian标志值”错误。 我一直在互联网上寻找解决方案,但到目前为止还没有一个解决方案。没有主意了。我需要帮助

情况就是这样

实体类:

import com.vividsolutions.jts.geom.Point;
import com.vividsolutions.jts.geom.Geometry;
import com.vividsolutions.jts.geom.LineString;
import com.vividsolutions.jts.geom.Polygon;

@Entity
public class PontodeInteresse implements Serializable {

    private static final long serialVersionUID = 1L;

    @Id
    @GeneratedValue(strategy = GenerationType.SEQUENCE)
    private Long id;

    private String descricao;

    private Point ponto;

    private LineString linha;

    private Geometry geometry;

    private Polygon poligono;

    /* Getters and setters */
我可以从代码中插入多边形。一切似乎都很好:

public void criarGeometry () {
    PontodeInteresse ponto = new PontodeInteresse();

    GeometryFactory gf = new GeometryFactory();

    LinearRing shell = gf.createLinearRing(new Coordinate[] {
                                new Coordinate(-43.5552982, -22.8839067), new Coordinate(-43.5556591, -22.8838402),
                                new Coordinate(-43.5554786, -22.8829425), new Coordinate(-43.5555869, -22.8824438),
                                new Coordinate(-43.5552982, -22.8839067)});
    LinearRing[] holes = new LinearRing[0];
    Polygon polygon = gf.createPolygon(shell, holes);        
    ponto.setGeometry(polygon);
    colocar(ponto);
}
但是,当我尝试从testar()方法(如下)运行一个简单的地理空间查询时,会出现“遇到无效的endian标志值”错误。 我已经尝试使用@Column并设置地理类型,但没有成功。 如果我尝试从PgAdmin运行此查询,则会发生相同的错误:

从PontodeInterest中选择ST_AsGeoJSON(ST_GeoFromWKB(geometry))

   public void testar() {
        try {
            GeometryFactory gf = new GeometryFactory();
            Point pontoDentro = gf.createPoint( new Coordinate(-43.5658, -22.8722) );
            PontodeInteresse bairro = null;
            bairro = (PontodeInteresse) entityManager.createQuery("select p from PontodeInteresse p where contains(p.geometry, :ponto) = true").setParameter("ponto",pontoDentro).getSingleResult();
            if (bairro != null) {
                resultado = "OK";
            } else {
                resultado = "ERRO";    
            }//if
        } catch(Exception e) {
            System.out.println(e.getMessage());
        }//try
    }
POM依赖项包括:

<dependency>
    <groupId>com.vividsolutions</groupId>
    <artifactId>jts</artifactId>
    <version>1.13</version>
</dependency>
<dependency>
    <groupId>org.hibernate</groupId>
    <artifactId>hibernate-spatial</artifactId>
    <version>5.1.0.Final</version>
</dependency>
<dependency>
    <groupId>org.hibernate</groupId>
    <artifactId>hibernate-core</artifactId>
    <version>5.1.0.Final</version>
</dependency>
<dependency>
    <groupId>org.hibernate</groupId>
    <artifactId>hibernate-entitymanager</artifactId>
    <version>4.3.1.Final</version>
</dependency>

com.com解决方案
jts
1.13
org.hibernate
冬眠空间
5.1.0.1最终版本
org.hibernate
冬眠核心
5.1.0.1最终版本
org.hibernate
休眠实体管理器
4.3.1.最终版本
persistence.xml文件:

<?xml version="1.0" encoding="UTF-8"?>
<persistence version="2.0" xmlns="http://java.sun.com/xml/ns/persistence" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://java.sun.com/xml/ns/persistence http://java.sun.com/xml/ns/persistence/persistence_2_0.xsd">
  <persistence-unit name="projetoX_PU" transaction-type="JTA">
    <provider>org.hibernate.ejb.HibernatePersistence</provider>
    <jta-data-source>java:/jboss/datasources/projectNameDS</jta-data-source>
    <exclude-unlisted-classes>false</exclude-unlisted-classes>
    <properties>
      <property name="hibernate.hbm2ddl.auto" value="update"/>
      <property name="hibernate.dialect" value="org.hibernate.spatial.dialect.postgis.PostgisDialect"/>
    </properties>
  </persistence-unit>
</persistence>

org.hibernate.ejb.HibernatePersistence
java:/jboss/datasources/projectNameDS
假的

谢谢是advance

请检查您的hibernate方言是否正确设置为Postgis方言

下面是一个Spring boot应用程序的示例

spring.jpa.properties.hibernate.dialect=org.hibernate.spatial.dialect.postgis.PostgisDialect