来自Maven的Bean中的UnknownEntityTypeException

时间:2017-02-27 04:09:23

标签: hibernate maven jpa-2.1

我一直在尝试重构一个java项目,将子模块移动到部署到我们内部maven存储库(archiva)的单独项目中。

子模块中的类如下:

org.example.srv.DomainUser
org.example.srv.DomainUserBean //entity manager
org.example.srv.UserGroup
org.example.srv.UserGroupBean //entity manager

当源文件被复制到主后端服务器项目内的相应包文件夹中时,它工作正常,但是当我们从后端服务器项目中删除源文件并将相同的代码作为maven依赖项拉出时,我得到了尝试访问数据库时出现以下错误:

org.hibernate.UnknownEntityTypeException: Unable to locate persister: org.example.srv.DomainUser

后端服务器项目的持久性XML:

<?xml version="1.0" encoding="UTF-8"?>
<persistence version="2.1" xmlns="http://xmlns.jcp.org/xml/ns/persistence" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/persistence http://xmlns.jcp.org/xml/ns/persistence/persistence_2_1.xsd">
<persistence-unit name="loginserver">
    <properties>
        <property name="javax.persistence.schema-generation.database.action" value="drop-and-create"/>
    </properties>
</persistence-unit>
</persistence>

我只能想象当项目是分开的时候,它与bean发现有关,但我真的很困惑,用最小的配置开销来分离这些项目会很棒。

主服务器项目pom.xml:

<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>
    <groupId>org.example.srv</groupId>
    <artifactId>loginserver</artifactId>
    <version>0.0.2-SNAPSHOT</version>
    <packaging>war</packaging>
    <dependencies>
        <dependency>
            <groupId>javax</groupId>
            <artifactId>javaee-api</artifactId>
            <version>7.0</version>
            <scope>provided</scope>
        </dependency>
        <dependency>
            <groupId>com.unboundid</groupId>
            <artifactId>unboundid-ldapsdk</artifactId>
            <version>3.2.0</version>
        </dependency>
        <dependency>
            <groupId>org.example</groupId>
            <artifactId>authobjects</artifactId>
            <version>1.0.0</version>
        </dependency>
    </dependencies>
    <build>
        <finalName>loginserver</finalName>
    </build>
    <properties>
        <maven.compiler.source>1.8</maven.compiler.source>
        <maven.compiler.target>1.8</maven.compiler.target>
        <failOnMissingWebXml>false</failOnMissingWebXml>
    </properties>
</project>

Auth Objects pom.xml(此项目还包含类的ORM代码,包括JPQL语句构建器等):

<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>
    <properties>
        <pj.gid>org.example</pj.gid>
        <pj.aid>authobjects</pj.aid>
        <pj.ver>1.0.2-SNAPSHOT</pj.ver>
        <maven.compiler.source>1.8</maven.compiler.source>
        <maven.compiler.target>1.8</maven.compiler.target>
    </properties>

    <groupId>${pj.gid}</groupId>
    <artifactId>${pj.aid}</artifactId>
    <version>${pj.ver}</version>

    <dependencies>
        <dependency>
            <groupId>javax</groupId>
            <artifactId>javaee-api</artifactId>
            <version>7.0</version>
            <scope>provided</scope>
        </dependency>
        <dependency>
            <groupId>ent.tnp.utils</groupId>
            <artifactId>genericentityejb</artifactId>
            <version>1.0.0</version>
        </dependency>
    </dependencies>

    <build>
        <extensions>
            <extension>
                <groupId>org.apache.maven.wagon</groupId>
                <artifactId>wagon-webdav</artifactId>
                <version>1.0-beta-2</version>
            </extension>
        </extensions>
    </build>

    <distributionManagement>
        <repository>
            <id>internal</id>
            <url>http://archiva.tnp.in/repository/internal/</url>
        </repository>
        <snapshotRepository>
            <id>snapshots</id>
            <url>http://archiva.tnp.in/repository/snapshots/</url>
        </snapshotRepository>
    </distributionManagement>

    <repositories>
        <repository>
            <id>internal</id>
            <name>Archiva Managed Internal Repository</name>
            <url>http://archiva.tnp.in/repository/internal/</url>
            <releases>
                <enabled>true</enabled>
            </releases>
            <snapshots>
                <enabled>false</enabled>
            </snapshots>
        </repository>
        <repository>
            <id>snapshots</id>
            <name>Archiva Managed Snapshot Repository</name>
            <url>http://archiva.tnp.in/repository/snapshots/</url>
            <releases>
                <enabled>false</enabled>
            </releases>
            <snapshots>
                <enabled>true</enabled>
            </snapshots>
        </repository>
    </repositories>
    <pluginRepositories>
        <pluginRepository>
            <id>internal</id>
            <name>Archiva Managed Internal Repository</name>
            <url>http://archiva.tnp.in/repository/internal/</url>
            <releases>
                <enabled>true</enabled>
            </releases>
            <snapshots>
                <enabled>false</enabled>
            </snapshots>
        </pluginRepository>
        <pluginRepository>
            <id>snapshots</id>
            <name>Archiva Managed Snapshot Repository</name>
            <url>http://archiva.tnp.in/repository/snapshots/</url>
            <releases>
                <enabled>false</enabled>
            </releases>
            <snapshots>
                <enabled>true</enabled>
            </snapshots>
        </pluginRepository>
    </pluginRepositories>

</project>

澄清:genericentityejb是一个抽象类,旨在组合JPQL查询并管理JPA实体的数据库查询。 authobjects项目为它包含的每个实体扩展一次,以便为每个实体提供持久性。

2 个答案:

答案 0 :(得分:3)

据我所知,至少涉及 4 模块:

  • org.example.srv:loginserver:0.0.2-SNAPSHOT

    • org.example:authobjects:1.0.0
  • org.example:authobjects:1.0.2-SNAPSHOT

    • ent.tnp.utils:genericentityejb:1.0.0

我注意到一些可能的重要性:

  1. loginserver不依赖于authobjects,而是依赖于genericentityejb(它们是两个不相关的示例项目吗?)。
  2. loginserver不依赖于authobjects:1.0.2-SNAPSHOT,而是依赖于authobjects:1.0.0
  3. loginserver未声明任何存储库(既不是父POM),因此始终从本地计算机存储库中解析genericentityejb,除非您在全球settings.xml中声明了存储库(可以)。
  4. 我不确定使用authobjects项目groupId,artifactId和版本的属性是个好主意。也许它没有关联,但我要避免这样的声明。
  5. 话虽这么说,我在项目中使用了类似的结构,部署到Wildfly 10.1,Hibernate正确地发现了所有依赖项中的所有实体。

    所以我试试干净的一轮。 我会忽略authobjects,因为它没有被引用,我认为所需的实体类在genericentityejb中:

    1. genericentityejb POM版本修改为1.0.1-SNAPSHOT
    2. 来自genericentityejb文件夹:mvn clean install
    3. authobjects POM版本修改为1.0.3-SNAPSHOT,将genericentityejb修改为1.0.1-SNAPSHOT
    4. 来自authobjects文件夹:mvn clean install
    5. loginserver依赖项authobjects修改为0.0.3-SNAPSHOT,将依赖项authobjects修改为1.0.3-SNAPSHOT
    6. loginserver文件夹:mvn dependency:analyze检查已使用的未声明代码(可能是genericentityejb?)
    7. 来自loginserver文件夹:mvn clean package
    8. 检查是否存在loginserver/target/loginserver-0.0.3-SNAPSHOT.war!/WEB-INF/lib/genericentityejb-1.0.3-SNAPSHOT.jarloginserver/target/loginserver-0.0.3-SNAPSHOT.war!/WEB-INF/lib/authobjects-0.0.3-SNAPSHOT.jar并包含所有实体类。
    9. 查看loginserver effective POM

      也很有用

      pom.xmlsettings.xml中声明存储库是个人选择。这两种方法都有利有弊:

      • 复制&#39; n&#39;粘贴存储库

        • pom:每个新项目
        • 设置:对于每台新机器(开发人员,CI环境,......)
      • 编辑回购网址

        • pom:每个项目
        • 设置:适用于每台机器
      • 发布工件时
        • pom:repo refes刻在那个版本的石头上
        • 设置:该版本中使用的repo refes未保存

答案 1 :(得分:1)

您可以将<jar-file>元素(包含带有实体clases的jar的路径)添加到persistence.xml,或使用<class>元素描述所有实体类。

此外,您可以使用某种程序包扫描方法以编程方式添加实体类。我在这里为这种方法收集了有用的链接和库:

https://github.com/v-ladynev/hibernate-scanners-test