0

0

在WildFly中集成EJB与JAX-WS:解决部署与访问难题

霞舞

霞舞

发布时间:2025-09-01 12:27:07

|

842人浏览过

|

来源于php中文网

原创

在WildFly中集成EJB与JAX-WS:解决部署与访问难题

本文详细介绍了在WildFly应用服务器上,将EJB(Enterprise JavaBeans)与JAX-WS(Java API for XML Web Services)项目整合到EAR(Enterprise Archive)中的实践。教程涵盖了多模块Maven项目结构、依赖管理、以及如何解决部署过程中常见的NoClassDefFoundError类加载问题,并指导读者正确访问已部署Web服务的WSDL定义。

概述:EJB与JAX-WS在EAR中的集成

在企业级java应用开发中,将业务逻辑封装为ejb,并通过jax-ws暴露为web服务是一种常见模式。为了更好地管理和部署这些组件,通常会将它们打包到一个ear文件中。本教程将以一个典型的多模块maven项目为例,演示如何配置项目、解决部署时可能遇到的类加载问题,并最终成功访问web服务。

项目结构与Maven依赖管理

一个典型的EJB与JAX-WS集成项目通常包含以下Maven模块:

  • 父项目 (myapp-app): 管理所有子模块的公共依赖和版本。
  • EJB模块 (myapp-ejb): 包含业务逻辑的EJB接口和实现。
  • Web服务模块 (myapp-ws): 包含JAX-WS服务接口和实现,并通过@EJB注解注入EJB。
  • EAR模块 (myapp-ear): 将EJB模块和Web服务模块打包在一起,形成一个可部署的企业级应用。

以下是相关pom.xml文件的关键配置片段,展示了这些模块之间的依赖关系:

1. 父项目 pom.xml (myapp-app)


    4.0.0
    org.myapp
    myapp-app
    pom
    0.1.0
    
        myapp-ejb
        myapp-web      
        myapp-ear
        myapp-ws       
    
    
        UTF-8
        1.8
        1.8
        18.0.1.Final
    
    
        
            
                org.wildfly.bom
                wildfly-jakartaee8-with-tools
                ${version.server.bom}
                pom
                import
                           
            
                ${project.groupId}
                myapp-ejb
                ${project.version}
                ejb
            
            
                ${project.groupId}
                myapp-ws
                ${project.version}
                war
                compile
                               
        
    
    

2. EAR项目 pom.xml (myapp-ear)

EAR项目负责将WAR和EJB打包。请确保在dependencies中正确引用了EJB和Web服务模块。


    4.0.0
    org.myapp
    myapp-ear
    ear
    0.1.0
    myapp-ear
    
        org.myapp
        myapp-app
        0.1.0
    
    
        
            ${project.groupId}
            myapp-ejb
            ejb
            0.1.0
        
        
            ${project.groupId}
            myapp-ws
            war
            0.1.0 
               
    
    

3. Web服务项目 pom.xml (myapp-ws)

Web服务模块需要EJB接口来进行编译和类型检查,但在运行时,EJB实例将由容器提供。因此,将EJB模块的依赖范围设置为provided是关键,这可以避免将EJB JAR重复打包到WAR中,并依赖EAR容器的类加载机制。


    4.0.0
    org.myapp
    myapp-ws
    war
    0.1.0
    myapp-ws Maven Soap WS
    
        org.myapp
        myapp-app
        0.1.0
    
    
        
        
            ${project.groupId}
            myapp-ejb
            ejb
            provided
        
    
    

解决部署时的NoClassDefFoundError

在WildFly中,当一个WAR包部署在EAR内部时,它通常可以访问EAR中其他模块(如EJB JAR)的类。然而,有时会遇到java.lang.NoClassDefFoundError或java.lang.ClassNotFoundException,特别是在Web服务模块尝试通过反射获取EJB接口信息时。错误信息通常类似:

WFLYSRV0153: Failed to process phase POST_MODULE of deployment "myapp-ws.war"
Caused by: java.lang.RuntimeException: WFLYSRV0177: Error getting reflective information for class org.ws.MyAppWSImpl with ClassLoader ModuleClassLoader for Module "deployment.myapp-ws.war"
Caused by: java.lang.NoClassDefFoundError: Lorg/myapp/MyAppStatelessLocal;
Caused by: java.lang.ClassNotFoundException: org.myapp.MyAppStatelessLocal from [Module "deployment.myapp-ws.war"]

这表明尽管myapp-ejb被包含在EAR中,但myapp-ws.war的类加载器在部署阶段未能找到MyAppStatelessLocal接口。为了明确告知WildFly myapp-ws.war依赖于myapp-ejb.jar,可以在myapp-ws.war的WEB-INF/目录下添加一个jboss-deployment-structure.xml文件。

1. 创建 jboss-deployment-structure.xml

在myapp-ws项目的src/main/webapp/WEB-INF/目录下创建或编辑jboss-deployment-structure.xml文件,内容如下:



    
        
            
            
        
    

这里的module name格式deployment..ear.是WildFly中引用EAR内部子部署的约定。这会确保myapp-ws.war的类加载器能够正确地访问myapp-ejb.jar中的类。

2. Web服务实现 (MyAppWSImpl.java)

LongCat AI
LongCat AI

美团推出的AI对话问答工具

下载

Web服务实现类通过@EJB注解注入EJB,这是Java EE规范的标准做法。

package myapp.ws;

import javax.ejb.EJB;
import javax.jws.WebMethod;
import javax.jws.WebService;
import myapp.lab.MyAppStatelessLocal; // 确保导入EJB接口

@WebService(endpointInterface = "myapp.ws.MyAppWS")
public class MyAppWSImpl implements MyAppWS {
    @EJB
    MyAppStatelessLocal masl; // 注入EJB本地接口

    @WebMethod()
    public String predict(int value) {
        return masl.getPrediction(value);
    }
}

3. Web服务配置 (web.xml)

web.xml用于配置Servlet和Servlet映射,JAX-WS服务通常通过Servlet暴露。



  myapp-ws
  
    index.html
  

  
    myappws
    myapp.ws.MyAppWSImpl
  
  
    myappws
    /myappws
  

这里的定义了Web服务的访问路径,这对于后续访问WSDL至关重要。

访问已部署Web服务的WSDL

在成功部署EAR文件到WildFly服务器后,Web服务即可通过HTTP协议访问。为了获取Web服务的WSDL(Web Services Description Language)定义,需要使用正确的URL。

根据web.xml中定义的,Web服务的访问路径是/myappws。因此,正确的WSDL访问URL应为:

http://localhost:8080/myapp-ws/myappws?wsdl

注意事项:

  • localhost:8080是WildFly服务器的默认地址和端口,如果你的配置不同,请相应修改。
  • myapp-ws是Web服务模块的上下文根(通常与WAR文件的名称相同)。
  • myappws是web.xml中定义的url-pattern。
  • ?wsdl是标准后缀,用于请求Web服务的WSDL定义。

错误地使用服务实现类名(例如http://localhost:8080/myapp-ws/MyAppWSImpl?wsdl)将无法获取WSDL,因为JAX-WS运行时通常根据web.xml中的Servlet映射来暴露WSDL,而不是直接基于实现类名。

总结与最佳实践

在WildFly中集成EJB与JAX-WS并将其打包到EAR中,需要细致的Maven配置和对Java EE类加载机制的理解。

  1. Maven依赖管理:确保EJB模块在Web服务模块中被声明为provided范围,避免JAR文件重复打包。
  2. EAR打包:myapp-ear的pom.xml必须正确引用所有内部模块(EJB JAR和WAR)。
  3. WildFly类加载:当遇到NoClassDefFoundError时,jboss-deployment-structure.xml是解决WAR内部模块对EAR中其他模块(如EJB)显式依赖的有效方法。
  4. Web服务配置:web.xml中的定义了Web服务的实际访问路径,这直接影响WSDL的URL。

遵循这些步骤和最佳实践,可以有效地在WildFly环境中构建和部署健壮的企业级Web服务应用。

相关专题

更多
java
java

Java是一个通用术语,用于表示Java软件及其组件,包括“Java运行时环境 (JRE)”、“Java虚拟机 (JVM)”以及“插件”。php中文网还为大家带了Java相关下载资源、相关课程以及相关文章等内容,供大家免费下载使用。

831

2023.06.15

java正则表达式语法
java正则表达式语法

java正则表达式语法是一种模式匹配工具,它非常有用,可以在处理文本和字符串时快速地查找、替换、验证和提取特定的模式和数据。本专题提供java正则表达式语法的相关文章、下载和专题,供大家免费下载体验。

737

2023.07.05

java自学难吗
java自学难吗

Java自学并不难。Java语言相对于其他一些编程语言而言,有着较为简洁和易读的语法,本专题为大家提供java自学难吗相关的文章,大家可以免费体验。

733

2023.07.31

java配置jdk环境变量
java配置jdk环境变量

Java是一种广泛使用的高级编程语言,用于开发各种类型的应用程序。为了能够在计算机上正确运行和编译Java代码,需要正确配置Java Development Kit(JDK)环境变量。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

397

2023.08.01

java保留两位小数
java保留两位小数

Java是一种广泛应用于编程领域的高级编程语言。在Java中,保留两位小数是指在进行数值计算或输出时,限制小数部分只有两位有效数字,并将多余的位数进行四舍五入或截取。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

398

2023.08.02

java基本数据类型
java基本数据类型

java基本数据类型有:1、byte;2、short;3、int;4、long;5、float;6、double;7、char;8、boolean。本专题为大家提供java基本数据类型的相关的文章、下载、课程内容,供大家免费下载体验。

446

2023.08.02

java有什么用
java有什么用

java可以开发应用程序、移动应用、Web应用、企业级应用、嵌入式系统等方面。本专题为大家提供java有什么用的相关的文章、下载、课程内容,供大家免费下载体验。

430

2023.08.02

java在线网站
java在线网站

Java在线网站是指提供Java编程学习、实践和交流平台的网络服务。近年来,随着Java语言在软件开发领域的广泛应用,越来越多的人对Java编程感兴趣,并希望能够通过在线网站来学习和提高自己的Java编程技能。php中文网给大家带来了相关的视频、教程以及文章,欢迎大家前来学习阅读和下载。

16925

2023.08.03

Java 项目构建与依赖管理(Maven / Gradle)
Java 项目构建与依赖管理(Maven / Gradle)

本专题系统讲解 Java 项目构建与依赖管理的完整体系,重点覆盖 Maven 与 Gradle 的核心概念、项目生命周期、依赖冲突解决、多模块项目管理、构建加速与版本发布规范。通过真实项目结构示例,帮助学习者掌握 从零搭建、维护到发布 Java 工程的标准化流程,提升在实际团队开发中的工程能力与协作效率。

10

2026.01.12

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Kotlin 教程
Kotlin 教程

共23课时 | 2.4万人学习

C# 教程
C# 教程

共94课时 | 6.5万人学习

Java 教程
Java 教程

共578课时 | 45.2万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号