2011-09-14 2 views
2

내 ejb 프로젝트에서 DataObjectEntity.java라는 추상 엔티티 클래스를 정의하고 모든 엔티티가이 클래스를 확장하도록했습니다. 공통 필드를 재사용 할 수 있고 시스템에서 활동을 기록하는 것이 더 쉬울 수있는 목적입니다.java.lang.NoClassDefFoundError를 발생시키는 EJB 추상 엔티티?

그런 다음 엔티티 클래스에서 JSF 페이지를 생성하기 위해 netbeans의 내장 기능을 사용했습니다. 모든 것이 괜찮았다. 나는 프로젝트를 잘 진행할 수 있었다.

하지만 새로운 엔티티를 추가 한 후 배포 할 때 수퍼 클래스 엔티티에 대해이 NoClassDefFoundError를 얻었습니다. 새로운 엔티티는 기존 엔티티 클래스 중 하나와 정의 된 1-1 관계로 정말 간단했습니다. 내가 생각할 수있는 모든 것을 시도했다. 깨끗한 & build, glassfish 다시 시작, 모든 테이블 삭제, 새로운 엔티티 클래스 용 JSF 생성.

결국 엔 새 엔티티를 삭제하고 기존의 백업 콩만 변경했습니다. 그리고 그 오류는 여전히 지속됩니다. 나는 심지어 새로운 작업 복사본을 체크 아웃하여 백킹 빈에 동일한 변경 사항을 적용했다. 복사본이 잘 배치되었다는 것이 밝혀졌다. 내 팀원 중 한 명이 새로운 항목을 추가하려고 할 때 정확히 동일한 오류가 발생합니다. 어떤 생각이 그 원인일까요?

WARNING: entity/DataObjectEntity_ 
java.lang.NoClassDefFoundError: entity/DataObjectEntity_ 
at java.lang.ClassLoader.defineClass1(Native Method) 
at java.lang.ClassLoader.defineClassCond(ClassLoader.java:631) 
at java.lang.ClassLoader.defineClass(ClassLoader.java:615) 
at java.security.SecureClassLoader.defineClass(SecureClassLoader.java:141) 
at org.glassfish.web.loader.WebappClassLoader.findClass(WebappClassLoader.java:927) 
at org.glassfish.web.loader.WebappClassLoader.loadClass(WebappClassLoader.java:1486) 
at org.glassfish.web.loader.WebappClassLoader.loadClass(WebappClassLoader.java:1369) 
at java.lang.Class.forName0(Native Method) 
at java.lang.Class.forName(Class.java:247) 
at org.eclipse.persistence.internal.helper.ConversionManager.convertObjectToClass(ConversionManager.java:438) 
at org.eclipse.persistence.internal.helper.ConversionManager.convertObject(ConversionManager.java:141) 
at org.eclipse.persistence.internal.databaseaccess.DatasourcePlatform.convertObject(DatasourcePlatform.java:160) 
at org.eclipse.persistence.internal.jpa.EntityManagerSetupImpl.initializeCanonicalMetamodel(EntityManagerSetupImpl.java:2552) 
at org.eclipse.persistence.internal.jpa.EntityManagerSetupImpl.getMetamodel(EntityManagerSetupImpl.java:2531) 
at org.eclipse.persistence.internal.jpa.EntityManagerSetupImpl.deploy(EntityManagerSetupImpl.java:484) 
at org.eclipse.persistence.internal.jpa.EntityManagerFactoryDelegate.getDatabaseSession(EntityManagerFactoryDelegate.java:188) 
at org.eclipse.persistence.internal.jpa.EntityManagerFactoryDelegate.createEntityManagerImpl(EntityManagerFactoryDelegate.java:277) 
at org.eclipse.persistence.internal.jpa.EntityManagerFactoryImpl.createEntityManagerImpl(EntityManagerFactoryImpl.java:290) 
at org.eclipse.persistence.internal.jpa.EntityManagerFactoryImpl.createEntityManager(EntityManagerFactoryImpl.java:268) 
at org.glassfish.persistence.jpa.PersistenceUnitLoader.doJava2DB(PersistenceUnitLoader.java:373) 
at org.glassfish.persistence.jpa.JPADeployer$2.visitPUD(JPADeployer.java:435) 
at org.glassfish.persistence.jpa.JPADeployer$PersistenceUnitDescriptorIterator.iteratePUDs(JPADeployer.java:483) 
at org.glassfish.persistence.jpa.JPADeployer.iterateInitializedPUsAtApplicationPrepare(JPADeployer.java:465) 
at org.glassfish.persistence.jpa.JPADeployer.event(JPADeployer.java:386) 
at org.glassfish.kernel.event.EventsImpl.send(EventsImpl.java:128) 
at com.sun.enterprise.v3.server.ApplicationLifecycle.deploy(ApplicationLifecycle.java:453) 
at com.sun.enterprise.v3.server.ApplicationLifecycle.deploy(ApplicationLifecycle.java:240) 
at org.glassfish.deployment.admin.DeployCommand.execute(DeployCommand.java:382) 
at com.sun.enterprise.v3.admin.CommandRunnerImpl$1.execute(CommandRunnerImpl.java:355) 
at com.sun.enterprise.v3.admin.CommandRunnerImpl.doCommand(CommandRunnerImpl.java:370) 
at com.sun.enterprise.v3.admin.CommandRunnerImpl.doCommand(CommandRunnerImpl.java:1064) 
at com.sun.enterprise.v3.admin.CommandRunnerImpl.access$1200(CommandRunnerImpl.java:96) 
at com.sun.enterprise.v3.admin.CommandRunnerImpl$ExecutionContext.execute(CommandRunnerImpl.java:1244) 
at com.sun.enterprise.v3.admin.CommandRunnerImpl$ExecutionContext.execute(CommandRunnerImpl.java:1232) 
at com.sun.enterprise.v3.admin.AdminAdapter.doCommand(AdminAdapter.java:459) 
at com.sun.enterprise.v3.admin.AdminAdapter.service(AdminAdapter.java:209) 
at com.sun.grizzly.tcp.http11.GrizzlyAdapter.service(GrizzlyAdapter.java:168) 
at com.sun.enterprise.v3.server.HK2Dispatcher.dispath(HK2Dispatcher.java:117) 
at com.sun.enterprise.v3.services.impl.ContainerMapper.service(ContainerMapper.java:238) 
at com.sun.grizzly.http.ProcessorTask.invokeAdapter(ProcessorTask.java:828) 
at com.sun.grizzly.http.ProcessorTask.doProcess(ProcessorTask.java:725) 
at com.sun.grizzly.http.ProcessorTask.process(ProcessorTask.java:1019) 
at com.sun.grizzly.http.DefaultProtocolFilter.execute(DefaultProtocolFilter.java:225) 
at com.sun.grizzly.DefaultProtocolChain.executeProtocolFilter(DefaultProtocolChain.java:137) 
at com.sun.grizzly.DefaultProtocolChain.execute(DefaultProtocolChain.java:104) 
at com.sun.grizzly.DefaultProtocolChain.execute(DefaultProtocolChain.java:90) 
at com.sun.grizzly.http.HttpProtocolChain.execute(HttpProtocolChain.java:79) 
at com.sun.grizzly.ProtocolChainContextTask.doCall(ProtocolChainContextTask.java:54) 
at com.sun.grizzly.SelectionKeyContextTask.call(SelectionKeyContextTask.java:59) 
at com.sun.grizzly.ContextTask.run(ContextTask.java:71) 
at com.sun.grizzly.util.AbstractThreadPool$Worker.doWork(AbstractThreadPool.java:532) 
at com.sun.grizzly.util.AbstractThreadPool$Worker.run(AbstractThreadPool.java:513) 
at java.lang.Thread.run(Thread.java:680) 
Caused by: java.lang.ClassNotFoundException: entity.DataObjectEntity_ 
at org.glassfish.web.loader.WebappClassLoader.loadClass(WebappClassLoader.java:1519) 
at org.glassfish.web.loader.WebappClassLoader.loadClass(WebappClassLoader.java:1369) 
... 53 more 

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="MyProject-warPU" transaction-type="JTA"> 
    <provider>org.eclipse.persistence.jpa.PersistenceProvider</provider> 
    <jta-data-source>jdbc/myprojectdb</jta-data-source> 
    <exclude-unlisted-classes>false</exclude-unlisted-classes> 
    <properties> 
     <property name="eclipselink.ddl-generation" value="drop-and-create-tables"/> 
    </properties> 
    </persistence-unit> 
</persistence> 

업데이트 : 내 팀 동료가이 문제를 해결하는 아주 이상한하지만 유망한 방법 발견을 .class하는 NoClassDefFoundError를보고 엔티티 자바 파일의 이름을 변경합니다. 글래스 피쉬가 컴파일하고 오류를보고 할 때까지 기다리십시오. 그런 다음 다시 .java로 변경하십시오. 글래스 피쉬가 다시 컴파일되고 정리되고 전개 될 때까지 기다리십시오. 매번 작동합니다.

+0

통합 테스트가 있습니까? 그렇다면 전달합니다. persistence.xml을 붙여 넣습니다. 이 클래스를 사용하여 테스트 응용 프로그램을 만드는 것이 좋습니다. 해당 오류가 있으면 테스트 응용 프로그램의 전체 코드를 여기에 붙여 넣으십시오. 정말로 당신이 올린 글에서 아무 것도 말하기가 어렵습니다. – Shahzeb

+0

나는 createdBy = null을 추가하여 신비하게 "문제를 해결했다"; lastModifiedBy = null;'DataObjectEntity 클래스의 기본 생성자에서. 왜?! – Wei

+0

아마도 JPA2 메타 모델 클래스 ("_"접미어가 붙은 클래스)와 관련이 있으며 생성이 필요합니다. 결국 그것은 메시지에서 언급 된 것입니다. 왜 당신이 선택한 JPA 구현이 그 클래스에 문제가 없다면 다른 것인가 ... – DataNucleus

답변

1

예외는 클래스 엔티티/DataObjectEntity_가 아닌 DataObjectEntity입니다. "_"에 유의하십시오.

이것은 Criteria API의 유형 안전 버전에만 사용되는 JPA2 메타 모델 클래스입니다. 필수 사항은 아니며 문제가 발생하지 않아야합니다. 응용 프로그램이 여전히 성공적으로 실행됩니까?

이 모델 클래스는 선택 사항이며 일반적으로 필요하지 않으므로 누락되면 문제가 발생하지 않습니다. IDE 나 빌드 프로세스에 연결되어야하는 EclipseLinkk 메타 모델 생성기에 의해서만 컴파일 타임에 생성됩니다.

문제를 해결하기 위해 변경하면 의미가 없습니다. IDE에서 일부 컴파일 문제가 발생한 것처럼 보입니다.

+0

netbeans를 사용하고 있습니다. 그 이후로 같은 문제는 보지 못했지만 다른 팀원에게는 있습니다.그래도 DataObjectEntity의 하위 클래스 인 PersonEntity와 CustomerEntity 및 SystemUserEntity의 수퍼 클래스와 같은 ... 그리고 그는 그에 따라 Netbeans을 반복적으로 정리, 빌드, 다시 시작하고 다시 시작하여 결국 문제가 사라지게 만들었습니다 ... – Wei

관련 문제