2010-07-27 13 views
18

Weblogic 10.3'te Hibernate (dikişle birlikte kullan) ile ilgili büyük bir sorunum var. Başvurumu Yayınladığınızdajava.lang.NoSuchMethodException: org.hibernate.validator.ClassValidator Seam weblogic 10.3

, bu hatayı alıyorum:

java.lang.NoSuchMethodException: org.hibernate.validator.ClassValidator.<init>(java.lang.Class, java.util.ResourceBundle, org.hibernate.validator.MessageInterpolator, java.util.Map, org.hibernate.annotations.common.reflection.ReflectionManager) 

Bu hata compatibily hazırda kavanoz arasına gelebilir o web üzerinde okuyun. Ancak matrisi okudum ve iyi sürümlü iyi bir koda sahibim (hibernate-validator 3.1, hibernate-search 3.1, hibernate core 3.3.0)

Bu sorunu çözmek için bir fikrim yok. Birisi bana yardım edebilir mi?

Teşekkürler.

Not: Önceden paketlenmiş hazırda kavanozları (yani jboss sunucuyla birlikte) ise uygulamanızda Hibernate'in yeni bir sürümünü kullanan eski sürümün olduğunda

weblogic.application.ModuleException: 
     at weblogic.servlet.internal.WebAppModule.startContexts(WebAppModule.java:1373) 
     at weblogic.servlet.internal.WebAppModule.start(WebAppModule.java:468) 
     at weblogic.application.internal.flow.ModuleListenerInvoker.start(ModuleListenerInvoker.java:117) 
     at weblogic.application.internal.flow.ModuleStateDriver$3.next(ModuleStateDriver.java:204) 
     at weblogic.application.utils.StateMachineDriver.nextState(StateMachineDriver.java:37) 
     at weblogic.application.internal.flow.ModuleStateDriver.start(ModuleStateDriver.java:60) 
     at weblogic.application.internal.flow.StartModulesFlow.activate(StartModulesFlow.java:27) 
     at weblogic.application.internal.BaseDeployment$2.next(BaseDeployment.java:635) 
     at weblogic.application.utils.StateMachineDriver.nextState(StateMachineDriver.java:37) 
     at weblogic.application.internal.BaseDeployment.activate(BaseDeployment.java:212) 
     at weblogic.application.internal.EarDeployment.activate(EarDeployment.java:16) 
     at weblogic.application.internal.DeploymentStateChecker.activate(DeploymentStateChecker.java:162) 
     at weblogic.deploy.internal.targetserver.AppContainerInvoker.activate(AppContainerInvoker.java:79) 
     at weblogic.deploy.internal.targetserver.operations.AbstractOperation.activate(AbstractOperation.java:569) 
     at weblogic.deploy.internal.targetserver.operations.ActivateOperation.activateDeployment(ActivateOperation.java:140) 
     at weblogic.deploy.internal.targetserver.operations.ActivateOperation.doCommit(ActivateOperation.java:106) 
     at weblogic.deploy.internal.targetserver.operations.StartOperation.doCommit(StartOperation.java:143) 
     at weblogic.deploy.internal.targetserver.operations.AbstractOperation.commit(AbstractOperation.java:323) 
     at weblogic.deploy.internal.targetserver.DeploymentManager.handleDeploymentCommit(DeploymentManager.java:820) 
     at weblogic.deploy.internal.targetserver.DeploymentManager.activateDeploymentList(DeploymentManager.java:1227) 
     at weblogic.deploy.internal.targetserver.DeploymentManager.handleCommit(DeploymentManager.java:436) 
     at weblogic.deploy.internal.targetserver.DeploymentServiceDispatcher.commit(DeploymentServiceDispatcher.java:163) 
     at weblogic.deploy.service.internal.targetserver.DeploymentReceiverCallbackDeliverer.doCommitCallback(DeploymentReceiverCallbackDeliverer.java:181) 
     at weblogic.deploy.service.internal.targetserver.DeploymentReceiverCallbackDeliverer.access$100(DeploymentReceiverCallbackDeliverer.java:12) 
     at weblogic.deploy.service.internal.targetserver.DeploymentReceiverCallbackDeliverer$2.run(DeploymentReceiverCallbackDeliverer.java:67) 
     at weblogic.work.SelfTuningWorkManagerImpl$WorkAdapterImpl.run(SelfTuningWorkManagerImpl.java:516) 
     at weblogic.work.ExecuteThread.execute(ExecuteThread.java:201) 
     at weblogic.work.ExecuteThread.run(ExecuteThread.java:173) 
    java.lang.NoSuchMethodException: org.hibernate.validator.ClassValidator.<init>(java.lang.Class, java.util.ResourceBundle, org.hibernate.validator.MessageInterpolator, java.util.Map, org.hibernate.annotations.common.reflection.ReflectionManager) 
     at java.lang.Class.getConstructor0(Class.java:2706) 
     at java.lang.Class.getDeclaredConstructor(Class.java:1985) 
     at org.hibernate.cfg.AnnotationConfiguration.secondPassCompile(AnnotationConfiguration.java:352) 
     at org.hibernate.cfg.Configuration.buildMappings(Configuration.java:1148) 
     at org.hibernate.ejb.Ejb3Configuration.buildMappings(Ejb3Configuration.java:1226) 
     at org.hibernate.ejb.EventListenerConfigurator.configure(EventListenerConfigurator.java:159) 
     at org.hibernate.ejb.Ejb3Configuration.configure(Ejb3Configuration.java:854) 
     at org.hibernate.ejb.Ejb3Configuration.configure(Ejb3Configuration.java:191) 
     at org.hibernate.ejb.Ejb3Configuration.configure(Ejb3Configuration.java:253) 
     at org.hibernate.ejb.HibernatePersistence.createEntityManagerFactory(HibernatePersistence.java:125) 
     at javax.persistence.Persistence.createEntityManagerFactory(Persistence.java:83) 
     at javax.persistence.Persistence.createEntityManagerFactory(Persistence.java:60) 
     at org.jboss.seam.persistence.EntityManagerFactory.createEntityManagerFactory(EntityManagerFactory.java:81) 
     at org.jboss.seam.persistence.EntityManagerFactory.startup(EntityManagerFactory.java:50) 
     at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) 
     at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39) 
     at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25) 
     at java.lang.reflect.Method.invoke(Method.java:597) 
     at org.jboss.seam.util.Reflections.invoke(Reflections.java:22) 
     at org.jboss.seam.util.Reflections.invokeAndWrap(Reflections.java:144) 
     at org.jboss.seam.Component.callComponentMethod(Component.java:2257) 
     at org.jboss.seam.Component.callCreateMethod(Component.java:2172) 
     at org.jboss.seam.Component.newInstance(Component.java:2132) 
     at org.jboss.seam.contexts.Contexts.startup(Contexts.java:304) 
     at org.jboss.seam.contexts.Contexts.startup(Contexts.java:278) 
     at org.jboss.seam.contexts.ServletLifecycle.endInitialization(ServletLifecycle.java:116) 
     at org.jboss.seam.init.Initialization.init(Initialization.java:740) 
     at org.jboss.seam.servlet.SeamListener.contextInitialized(SeamListener.java:36) 
     at weblogic.servlet.internal.EventsManager$FireContextListenerAction.run(EventsManager.java:465) 
     at weblogic.security.acl.internal.AuthenticatedSubject.doAs(AuthenticatedSubject.java:321) 
     at weblogic.security.service.SecurityManager.runAs(Unknown Source) 
     at weblogic.servlet.internal.EventsManager.notifyContextCreatedEvent(EventsManager.java:175) 
     at weblogic.servlet.internal.WebAppServletContext.preloadResources(WebAppServletContext.java:1785) 
     at weblogic.servlet.internal.WebAppServletContext.start(WebAppServletContext.java:3005) 
     at weblogic.servlet.internal.WebAppModule.startContexts(WebAppModule.java:1371) 
     at weblogic.servlet.internal.WebAppModule.start(WebAppModule.java:468) 
     at weblogic.application.internal.flow.ModuleListenerInvoker.start(ModuleListenerInvoker.java:117) 
     at weblogic.application.internal.flow.ModuleStateDriver$3.next(ModuleStateDriver.java:204) 
     at weblogic.application.utils.StateMachineDriver.nextState(StateMachineDriver.java:37) 
     at weblogic.application.internal.flow.ModuleStateDriver.start(ModuleStateDriver.java:60) 
     at weblogic.application.internal.flow.StartModulesFlow.activate(StartModulesFlow.java:27) 
     at weblogic.application.internal.BaseDeployment$2.next(BaseDeployment.java:635) 
     at weblogic.application.utils.StateMachineDriver.nextState(StateMachineDriver.java:37) 
     at weblogic.application.internal.BaseDeployment.activate(BaseDeployment.java:212) 
     at weblogic.application.internal.EarDeployment.activate(EarDeployment.java:16) 
     at weblogic.application.internal.DeploymentStateChecker.activate(DeploymentStateChecker.java:162) 
     at weblogic.deploy.internal.targetserver.AppContainerInvoker.activate(AppContainerInvoker.java:79) 
     at weblogic.deploy.internal.targetserver.operations.AbstractOperation.activate(AbstractOperation.java:569) 
     at weblogic.deploy.internal.targetserver.operations.ActivateOperation.activateDeployment(ActivateOperation.java:140) 
     at weblogic.deploy.internal.targetserver.operations.ActivateOperation.doCommit(ActivateOperation.java:106) 
     at weblogic.deploy.internal.targetserver.operations.StartOperation.doCommit(StartOperation.java:143) 
     at weblogic.deploy.internal.targetserver.operations.AbstractOperation.commit(AbstractOperation.java:323) 
     at weblogic.deploy.internal.targetserver.DeploymentManager.handleDeploymentCommit(DeploymentManager.java:820) 
     at weblogic.deploy.internal.targetserver.DeploymentManager.activateDeploymentList(DeploymentManager.java:1227) 
     at weblogic.deploy.internal.targetserver.DeploymentManager.handleCommit(DeploymentManager.java:436) 
     at weblogic.deploy.internal.targetserver.DeploymentServiceDispatcher.commit(DeploymentServiceDispatcher.java:163) 
     at weblogic.deploy.service.internal.targetserver.DeploymentReceiverCallbackDeliverer.doCommitCallback(DeploymentReceiverCallbackDeliverer.java:181) 
     at weblogic.deploy.service.internal.targetserver.DeploymentReceiverCallbackDeliverer.access$100(DeploymentReceiverCallbackDeliverer.java:12) 
     at weblogic.deploy.service.internal.targetserver.DeploymentReceiverCallbackDeliverer$2.run(DeploymentReceiverCallbackDeliverer.java:67) 
     at weblogic.work.SelfTuningWorkManagerImpl$WorkAdapterImpl.run(SelfTuningWorkManagerImpl.java:516) 
     at weblogic.work.ExecuteThread.execute(ExecuteThread.java:201) 
     at weblogic.work.ExecuteThread.run(ExecuteThread.java:173) 
    > 
+0

Temizlemeyi ve oluşturmayı deneyin. – TaherT

+0

Bunu denedim, çok zaman;) ve hiçbir şey değişmedi – Kiva

cevap

13

Olur: İşte tam yığın izidir. Uygulama sunucunuzun hazırda bulunan kavanozlarını nasıl doğru şekilde yükselteceğinize dair ayrıntılar için, this'u okuyun.

+1

parlak! Bunu nasıl bilebilirsin? –

+4

Çünkü bu acıdan geçtim. – user18943

+0

sadece küçük bir soru, çatışmadan kaçınmanın en iyi yolunu biliyor musunuz? Çatışma meydana geldiğinde hata oluşmaz Hata Oluşumu –

12

Bu iki özelliği hazırda bekletme yapılandırmamda ekleyerek bu sorunu çözdüm. Düzgün ile

<weblogic-application> 
    <prefer-application-packages> 
     <package-name>org.hibernate.*</package-name> 
    </prefer-application-packages> 
</weblogic-application> 

: Eğer Weblogic Server bu sorunu vurmak edersek

<property name="hibernate.validator.apply_to_ddl">false</property> 
<property name="hibernate.validator.autoregister_listeners">false</property> 
+0

İşte bu kadar !! Hibernate 3.6.0.Final ve JBoss 4.2.1.GA ile benim için çalıştı. Çok çok teşekkürler !! – Donatello

+0

Günümü kurtardın ... bunu nasıl buldun? –

+0

Bu hazırda yapılandırma dosyası sunucuda mevcut mu? – dhroove

1

, ben EAR içinde weblogic-application.xml de prefer-application-packages Paketi org.hibernate yerleştirerek Weblogic 10.3.0.0 bu sorunu çözdü Bu uygulama, Weblogic Server'ın eski, çakışan kütüphaneyi sunucunun sınıf yolundan yüklemesini ve beklendiği gibi çalışmasını engelleyecektir.

İlgili konular