JBoss AS 7 миграция - java.lang.ClassNotFoundException: org.hibernate.validator.ClassValidator - PullRequest
7 голосов
/ 12 декабря 2011

У меня есть приложение, работающее на JBoss AS 4.2.3, и я пытаюсь перенести это на JBoss AS 7.0.2.Я также обновляю шов с 2.1.1 до 2.2.2.Я разрешил несколько исключений, не найденных в классе, но я застрял на

java.lang.ClassNotFoundException: org.hibernate.validator.ClassValidator

Моя полная трассировка стека ниже.

Я не оченьясно, о загрузчике нового класса в AS 7. Hibernate 4 работает со швом 2.2.2?Я попытался указать экспорт в jboss-deploy-structure.xml для использования org.hibernate и org.hibernate.validator.Однако, когда я смотрю в jar-файлы в этих местах, я не вижу класс ClassValidator ...

Я также пытался добавить jar-файлы hibernate 3 в EAR / lib и указать их в манифесте, но этоничего не меняет.Я вижу, что hibernate 3 hibernate-validator.jar действительно содержит класс classValidator, но все равно не находит его.

ОБНОВЛЕНИЕ Я также попробовал hibernate-validator-legacy-4.0.2.GA.jar

hibernate-annotations-3.4.0.GA.jar
hibernate-commons-annotations-3.1.0.GA.jar
hibernate-core-3.3.0.SP1.jar
hibernate-validator-3.1.0.GA.jar
14:16:07,776 INFO  [org.jboss.seam.Component] (MSC service thread 1-2) Component: Test, scope: EVENT, type: JAVA_BEAN, class: com.test.Test 
14:16:07,789 ERROR [org.apache.catalina.core.ContainerBase.[jboss.web].[default-host].[/oneSourceUI]] (MSC service thread 1-2) Exception sending context initialized event to listener instance of class org.jboss.seam.servlet.SeamListener: java.lang.RuntimeException: Could not create Component: Test
    at org.jboss.seam.init.Initialization.addComponent(Initialization.java:1202) [jboss-seam.jar:]
    at org.jboss.seam.init.Initialization.installComponents(Initialization.java:1118) [jboss-seam.jar:]
    at org.jboss.seam.init.Initialization.init(Initialization.java:737) [jboss-seam.jar:]
    at org.jboss.seam.servlet.SeamListener.contextInitialized(SeamListener.java:36) [jboss-seam.jar:]
    at org.apache.catalina.core.StandardContext.contextListenerStart(StandardContext.java:3368) [jbossweb-7.0.1.Final.jar:7.0.2.Final]
    at org.apache.catalina.core.StandardContext.start(StandardContext.java:3821) [jbossweb-7.0.1.Final.jar:7.0.2.Final]
    at org.jboss.as.web.deployment.WebDeploymentService.start(WebDeploymentService.java:70) [jboss-as-web-7.0.2.Final.jar:7.0.2.Final]
    at org.jboss.msc.service.ServiceControllerImpl$StartTask.startService(ServiceControllerImpl.java:1824)
    at org.jboss.msc.service.ServiceControllerImpl$StartTask.run(ServiceControllerImpl.java:1759)
    at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1110) [:1.7.0_01]
    at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:603) [:1.7.0_01]
    at java.lang.Thread.run(Thread.java:722) [:1.7.0_01]
Caused by: java.lang.NoClassDefFoundError: org/hibernate/validator/ClassValidator
    at java.lang.Class.getDeclaredMethods0(Native Method) [:1.7.0_01]
    at java.lang.Class.privateGetDeclaredMethods(Class.java:2442) [:1.7.0_01]
    at java.lang.Class.getDeclaredMethods(Class.java:1808) [:1.7.0_01]
    at org.jboss.seam.Component.initMembers(Component.java:553) [jboss-seam.jar:]
    at org.jboss.seam.Component.(Component.java:247) [jboss-seam.jar:]
    at org.jboss.seam.Component.(Component.java:208) [jboss-seam.jar:]
    at org.jboss.seam.init.Initialization.addComponent(Initialization.java:1186) [jboss-seam.jar:]
    ... 11 more
Caused by: java.lang.ClassNotFoundException: org.hibernate.validator.ClassValidator from [Module "deployment.test-ear.ear.jboss-seam.jar:main" from Service Module Loader]
    at org.jboss.modules.ModuleClassLoader.findClass(ModuleClassLoader.java:191)
    at org.jboss.modules.ConcurrentClassLoader.performLoadClassChecked(ConcurrentClassLoader.java:361)
    at org.jboss.modules.ConcurrentClassLoader.performLoadClassChecked(ConcurrentClassLoader.java:333)
    at org.jboss.modules.ConcurrentClassLoader.performLoadClass(ConcurrentClassLoader.java:310)
    at org.jboss.modules.ConcurrentClassLoader.loadClass(ConcurrentClassLoader.java:103)
    ... 18 more

14:16:07,798 INFO  [javax.enterprise.resource.webcontainer.jsf.config] (MSC service thread 1-2) Initializing Mojarra (1.2_15-20110809-SNAPSHOT) for context '/test
14:16:07,828 SEVERE [javax.enterprise.resource.webcontainer.jsf.application] (MSC service thread 1-2) JSF1051: Service entry 'org.jboss.as.web.deployment.jsf.JsfInjectionProvider' does not extend DiscoverableInjectionProvider.  Entry will be ignored.
14:16:07,829 INFO  [javax.enterprise.resource.webcontainer.jsf.application] (MSC service thread 1-2) JSF1048: PostConstruct/PreDestroy annotations present.  ManagedBeans methods marked with these annotations will have said annotations processed.
14:16:07,852 ERROR [org.apache.catalina.core.StandardContext] (MSC service thread 1-2) Error listenerStart
14:16:07,854 ERROR [org.apache.catalina.core.StandardContext] (MSC service thread 1-2) Context [/test] startup failed due to previous errors
14:16:07,855 INFO  [org.jboss.web] (MSC service thread 1-2) registering web context: /oneSourceUI
14:16:08,101 INFO  [org.apache.catalina.core.StandardContext] (MSC service thread 1-1) Container org.apache.catalina.core.ContainerBase.[jboss.web].[default-host].[/oneSourceUI] has not been started
14:16:08,816 INFO  [org.jboss.as.server.controller] (DeploymentScanner-threads - 2) Deployment of "test-ear.ear" was rolled back with failure message {"Services with missing/unavailable dependencies" => ["jboss.persistenceunit.\"test-ear.ear/test-ejb.jar#testBackout\" missing [ jboss.naming.context.java.testBackoutDatasource ]","jboss.persistenceunit.\"test-ear.ear/test-ejb.jar#test\" missing [ jboss.naming.context.java.testDatasource ]"]}
14:16:08,857 INFO  [org.jboss.as.server.deployment] (MSC service thread 1-1) Stopped deployment test-ejb.jar in 760ms
14:16:08,857 INFO  [org.jboss.as.server.deployment] (MSC service thread 1-1) Stopped deployment jboss-seam.jar in 761ms
14:16:09,613 INFO  [org.jboss.as.server.deployment] (MSC service thread 1-1) Stopped deployment oneSourceUI.war in 1517ms
14:16:09,720 INFO  [org.jboss.as.server.deployment] (MSC service thread 1-1) Stopped deployment oneSourceUI-ear.ear in 1624ms
14:16:09,728 ERROR [org.jboss.as.deployment] (DeploymentScanner-threads - 1) {"Composite operation failed and was rolled back. Steps that failed:" => {"Operation step-2" => {"Services with missing/unavailable dependencies" => ["jboss.persistenceunit.\"test-ear.ear/test-ejb.jar#testBackout\" missing [ jboss.naming.context.java.testBackoutDatasource ]","jboss.persistenceunit.\"test-ear.ear/test-ejb.jar#test\" missing [ jboss.naming.context.java.testDatasource ]"]}}}

Ответы [ 3 ]

5 голосов
/ 13 декабря 2011

Модель загрузки классов изменена в JBoss 7. Она скрывает много вещей, которые явно не объявлены.

Вы должны ознакомиться с этими ссылками:

https://docs.jboss.org/author/display/AS7/Developer+Guide#DeveloperGuide-HowtoresolveClassNotFoundExceptionsandNoCLassDefFoundErrors

https://docs.jboss.org/author/display/AS7/Class+Loading+in+AS7

3 голосов
/ 09 сентября 2013

1 - я решаю эту проблему, объявив модуль в jboss7.1.1 2 - изменить файл MANIFEST.MF в папке lib

в папке \ jboss-as-7.1.1.Final \ modules \ создайте следующие папки:

\ jboss-as-7.1.1.Final \ модули ** орг \ спящий режим \ валидатор \ главный **

затем я копирую файл hibernate-validator-4.2.0.Final.jar в папку main \

затем я создаю файл module.xml в главной папке и изменяю его следующим кодом:

<?xml version="1.0" encoding="UTF-8"?>
<module xmlns="urn:jboss:module:1.1" name="org.hibernate.validator">
  <resources>
    <resource-root path="hibernate-validator-4.2.0.Final.jar"/>
  </resources>

  <dependencies>
    <module name="javax.api"/>
    <module name="javax.persistence.api"/>
    <module name="javax.validation.api"/>
    <module name="javax.persistence.api"/>
    <module name="javax.xml.bind.api"/>
    <module name="org.jboss.logging"/>
    <module name="org.jboss.common-core"/>
    <module name="org.joda.time"/>
    <module name="org.slf4j"/>
    <module name="org.apache.xerces" services="import"/>
    <module name="sun.jdk" services="import"/>
  </dependencies>
</module>

Теперь ваш модуль создан в модулях jboss.

посмотрите на эту строку:

<module xmlns="urn:jboss:module:1.1" name="org.hibernate.validator">

вы должны использовать org.hibernate.validator в разделе Зависимости в вашем файле MANIFEST.MF, как показано ниже:

Manifest-Version: 1.0
Implementation-Vendor: Sahand Samaneh
Implementation-Title: Sahand System Security Product
Implementation-Version: 5.0.0-SNAPSHOT
Implementation-Vendor-Id: com.sahand.product
Built-By: pooladi.morteza
Build-Jdk: 1.6.0_21
Created-By: Apache Maven 3.0.4
Archiver-Version: Plexus Archiver
Dependencies: com.sahand.common.util,com.sahand.common.security,com.sahand.model.common,com.sahand.model.user.management,com.sahand.model.security,com.sahand.security.api,com.sahand.security.persistence,com.sahand.security.service,org.apache.commons.codec,org.slf4j,ch.qos.logback.core,ch.qos.logback.classic,javax.validation.api,org.hibernate.validator 

тогда ваша проблема должна пройти: D

если вы получаете какое-либо сообщение ClassNotFoundException, вы должны объявить модуль jboss и использовать его имя в файле MANIFEST.MF.

: D

0 голосов
/ 21 марта 2014

Поместив это в persistence.xml, я работал над этой ошибкой:

property name="javax.persistence.validation.mode" value="none"
...