Spring Boot 使用 WebServiceTemplate 调用 WebService 完整教程

WebServiceTemplateSpring 官方原生 的 SOAP 客户端工具,无需引入 CXF 等第三方框架,轻量、简单、和 SpringBoot 无缝整合,非常适合调用常规的 WebService(如你截图的 .NET ASMX 服务)。

下面给你 最简洁、可直接运行 的完整步骤,复制粘贴就能用。


一、核心依赖(只需这一个)

pom.xml 中添加 Spring 官方 WebService 启动器:

xml

复制代码
<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-web-services</artifactId>
</dependency>

<!-- 可选:XML 解析工具,处理 SOAP 响应 -->
<dependency>
    <groupId>org.dom4j</groupId>
    <artifactId>dom4j</artifactId>
    <version>2.1.4</version>
</dependency>

二、配置 WebServiceTemplate

创建配置类,初始化模板并指定 WebService 地址:

java

运行

复制代码
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.oxm.jaxb.Jaxb2Marshaller;
import org.springframework.ws.client.core.WebServiceTemplate;

@Configuration
public class WebServiceConfig {

    /**
     * 配置 WebService 客户端模板
     */
    @Bean
    public WebServiceTemplate webServiceTemplate() {
        WebServiceTemplate template = new WebServiceTemplate();
        
        // 设置你的 WebService 地址(.asmx 地址)
        template.setDefaultUri("http://10.38.113.72/WebService1.asmx");
        
        // 编码格式
        template.setMessageSender(messageSender());
        return template;
    }

    /**
     * HTTP 消息发送器(设置超时、编码)
     */
    @Bean
    public org.springframework.ws.transport.http.HttpComponentsMessageSender messageSender() {
        org.springframework.ws.transport.http.HttpComponentsMessageSender sender = new org.springframework.ws.transport.http.HttpComponentsMessageSender();
        sender.setConnectionTimeout(5000);
        sender.setReadTimeout(10000);
        return sender;
    }
}

三、编写调用工具类(两种方式任选)

方式 1:直接发送 SOAP 字符串(最简单,无需生成代码)

适合快速调用,手动拼 XML 报文,最通用。

java

运行

复制代码
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import org.springframework.ws.client.core.WebServiceTemplate;
import org.springframework.ws.soap.client.core.SoapActionCallback;

@Service
public class SoapClientService {

    @Autowired
    private WebServiceTemplate webServiceTemplate;

    /**
     * 调用 WebService 方法
     * @param param 传入参数
     * @return 返回结果
     */
    public String callWebService(String param) {
        // ===================== 1. 拼接 SOAP 请求 XML =====================
        // 从浏览器打开 ?wsdl 查看你的方法名和命名空间
        String soapXml = "<soap:Envelope xmlns:soap=\"http://schemas.xmlsoap.org/soap/envelope/\">\n" +
                "  <soap:Body>\n" +
                "    <HelloWorld xmlns=\"http://tempuri.org/\">\n" +
                "      <name>" + param + "</name>\n" +
                "    </HelloWorld>\n" +
                "  </soap:Body>\n" +
                "</soap:Envelope>";

        // ===================== 2. 设置 SOAPAction(.NET 必须) =====================
        // 格式:命名空间 + 方法名
        String soapAction = "http://tempuri.org/HelloWorld";
        SoapActionCallback callback = new SoapActionCallback(soapAction);

        // ===================== 3. 发送请求并获取响应 =====================
        Object response = webServiceTemplate.marshalSendAndReceive(soapXml, callback);

        // ===================== 4. 把响应转成字符串 =====================
        return response.toString();
    }
}

方式 2:使用 JAXB 对象自动转换(更优雅)

推荐正式项目使用,自动把 Java 对象转成 SOAP 请求,自动解析响应。

1)根据 WSDL 生成实体类(JDK 自带工具)

打开命令行执行:

bash

运行

复制代码
wsimport -p com.example.dto -keep http://10.38.113.72/WebService1.asmx?wsdl

会自动生成请求、响应、接口类。

2)配置转换器

java

运行

复制代码
@Bean
public Jaxb2Marshaller marshaller() {
    Jaxb2Marshaller marshaller = new Jaxb2Marshaller();
    // 填写生成类所在的包
    marshaller.setContextPath("com.example.dto");
    return marshaller;
}

@Bean
public WebServiceTemplate webServiceTemplate(Jaxb2Marshaller marshaller) {
    WebServiceTemplate template = new WebServiceTemplate();
    template.setDefaultUri("http://10.38.113.72/WebService1.asmx");
    // 绑定序列化工具
    template.setMarshaller(marshaller);
    template.setUnmarshaller(marshaller);
    return template;
}
3)直接用对象调用

java

运行

复制代码
public String callWithObject(String name) {
    // 生成的请求对象
    HelloWorld request = new HelloWorld();
    request.setName(name);

    // 调用
    HelloWorldResponse response = (HelloWorldResponse) webServiceTemplate.marshalSendAndReceive(request);
    
    return response.getHelloWorldResult();
}

四、关键注意事项(调用 .NET 必看)

  1. 必须加 SOAPAction .NET 的 WebService 强制要求请求头带 SOAPAction,格式:

    plaintext

    复制代码
    http://tempuri.org/方法名
  2. XML 命名空间必须正确 通常是:xmlns="http://tempuri.org/"

  3. 请求 XML 格式 直接浏览器打开你的服务:http://10.38.113.72/WebService1.asmx点击方法 → 就能看到官方示例 SOAP 请求体,直接复制使用即可。


五、测试调用

java

运行

复制代码
@Autowired
private SoapClientService soapClientService;

@Test
void testSoap() {
    String result = soapClientService.callWebService("张三");
    System.out.println("返回结果:" + result);
}

总结

  1. 依赖 :只需要 spring-boot-starter-web-services
  2. 核心工具WebServiceTemplate
  3. 调用方式
    • 简单场景:直接拼 XML 字符串
    • 正式项目:wsimport 生成对象 + JAXB 自动转换
  4. .NET 必备SOAPAction 请求头

如果你愿意,我可以根据你实际的 WSDL 地址,直接给你生成可运行的完整调用代码,你只需要复制到项目里就能用!

相关推荐
weixin_425023002 小时前
Spring Boot 2.7 + JDK 8 实现 WebSocket 集群分布式部署(基于 Redis Pub/Sub 方案)
java·spring boot·websocket
人道领域4 小时前
Day | 11 【苍穹外卖统计业务的实现:含详细思路分析】
java·数据库·后端·苍穹外卖
xiaoye37089 小时前
Java 自动装箱 / 拆箱 原理详解
java·开发语言
YDS82910 小时前
黑马点评 —— 分布式锁详解加源码剖析
java·spring boot·redis·分布式
KD10 小时前
阿里云服务迁移实战(二)——网关迁移与前后端分离配置
后端
迷藏49410 小时前
**发散创新:基于 Rust的开源权限管理系统设计与实战**在现代软件架构中,**权限控制**早已不
java·开发语言·rust·开源
升鲜宝供应链及收银系统源代码服务11 小时前
《IntelliJ + Claude Code + Gemini + ChatGPT 实战配置手册升鲜宝》
java·前端·数据库·chatgpt·供应链系统·生鲜配送
daidaidaiyu11 小时前
Nacos实例一则及其源码环境搭建
java·spring
小江的记录本11 小时前
【Redis】Redis全方位知识体系(附《Redis常用命令速查表(完整版)》)
java·数据库·redis·后端·python·spring·缓存