webService超时时间的JAVA中设置

本文介绍了在JAVA中调用SOAP和REST两种类型的WebService时如何设置超时时间。对于SOAP服务,通过Spring+CXF环境,可以配置ConnectionTimeout和ReceiveTimeout参数。而对于REST服务,可以通过HttpClient设置超时。内容详细解释了两个超时属性的作用,并提供了相关配置方法的参考资料。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

        目前比较常用的 WebService 有两种方式:SOAP和REST,本文就以调用这两种方式的服务,介绍编程中常用的超时设置,包括 JAVA调用远程 SOAP 服务,以及利用 HttpClient(JAVA调用 REST 服务(简单的 HTTP 服务)的超时问题。

一、webservice概念

        Web 服务是一个软件接口,它描述了一组可以在网络上通过标准化的 XML 消息传递访问的操作。Web Service 最基本的组成部分为服务的提供者(Service Provider)和服务的请求者(Service Requester)。Web Service 两端的应用是通过基于标准的 XML 格式的协议进行通信的,这种最常用的协议就是 SOAP(Simple Object Access Protocol)。

具体可参考:http://www.ruanyifeng.com/blog/2009/08/what_is_web_service.html

                       https://www.ibm.com/developerworks/cn/webservices/ws-wsar/part2/

二、SOAP服务

1、CXF

        在使用 WebService 的时候,我们可能需要一个备份的 WebService 服务器。一旦主服务器 down 了,我们可以使用备份的服务器。那么这里就需要对客服端连接服务器的时间做一个修改。

在 Spring+CXF 的 WebService 环境下,客户端有两个时间属性是可配置的,分别是 ConnectionTimeout 和ReceiveTimeout。

        ConnectionTimeout — WebService 以 TCP 连接为基础,这个属性可以理解为 tcp 的握手时的时间设置,超过设置的时间长则认为是连接超时,以毫秒为单位,默认是 30,000 毫秒,即 30 秒。

        ReceiveTimeout — 这个属性是发送 WebService 的请求后等待响应的时间,超过设置的时长就认为是响应超时,以毫秒为单位,默认是 60,000 毫秒,即60秒。

在调用 CXF 服务的 xml 文件中加入下面的配置:

<!-- 单个服务 -->
<?xml version="1.0" encoding="UTF-8"?>  
<beans xmlns="http://www.springframework.org/schema/beans"  
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"  
    xmlns:jee="http://www.springframework.org/schema/jee"  
    xmlns:jaxws="http://cxf.apache.org/jaxws"  
    xmlns:http-conf="http://cxf.apache.org/transports/http/configuration"   
    xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-2.0.xsd  
           http://www.springframework.org/schema/jee http://www.springframework.org/schema/jee/spring-jee-2.0.xsd  
           http://cxf.apache.org/jaxws http://cxf.apache.org/schemas/jaxws.xsd  
           http://cxf.apache.org/transports/http/configuration http://cxf.apache.org/schemas/configuration/http-conf.xsd ">  
    <http-conf:conduit name="{http://impl.service.izhangheng.com/}WebService.http-conduit">   
        <http-conf:client ConnectionTimeout="10000" ReceiveTimeout="30000"/>  
    </http-conf:conduit>
</beans> 

<!-- 所有服务 -->   
<http-conf:conduit name="*.http-conduit">  
    <http-conf:client ConnectionTimeout="10000" ReceiveTimeout="30000"/>   
</http-conf:conduit>
这里需要注意的有几个地方: 
1、需要指定 http-conf 名称空间:xmlns:http-conf=http://cxf.apache.org/transports/http/configuration
2、指定模式位置:http://cxf.apache.org/transports/http/configuration http://cxf.apache.org/schemas/configuration/http-conf.xsd

3、http-conf:conduit中的 name 属性,指定设置生效的服务。

详细参考:http://blog.youkuaiyun.com/shb_derek1/article/details/8018287

三、Rest

         代表性状态传输(Representational State Transfer,REST)在 Web 领域已经得到了广泛的接受,是基于 SOAP 和 Web 服务描述语言(Web Services Description Language,WSDL)的 Web 服务的更为简单的替代方法。接口设计方面这一转变的关键证据是主流 Web 2.0 服务提供者(包括 Yahoo、Google 和 Facebook)对 REST 的采用,这些提供者弃用或放弃了基于 SOAP 和 WSDL 的接口,而采用了更易于使用、面向资源的模型来公开其服务。如果考虑使用它的 Web 服务的数量,REST 近年来已经成为最主要的 Web 服务设计模型。

详细参考:https://www.ibm.com/developerworks/cn/webservices/ws-restful/

1、HttpClient

Java 利用 HttpClient 调用 REST 服务时,关键是给 HttpParams 设置超时,如下:

HttpParams params = new BasicHttpParams();
params.setParameter(CoreConnectionPNames.CONNECTION_TIMEOUT, 5*1000); //设置连接超时
params.setParameter(CoreConnectionPNames.SO_TIMEOUT, 30*1000); //等待数据的最大时
HttpClient client = new DefaultHttpClient(params);
<think>好的,我需要回答用户关于如何使用DynamicClientFactory创建客户端并设置超时时间的问题。首先,我要回忆CXF的相关知识,DynamicClientFactory用于动态创建客户端,不需要预生成存根。用户提到的引用[1]指出,DynamicClientFactory内部还是会生成代理类,但用户不需要手动处理。接下来,设置超时时间,通常涉及HTTPConduit的配置。引用[2]提到使用wsdl2java生成的客户端设置超时的方法,但用户需要动态客户端的做法。 我需要分步骤说明如何创建客户端,然后配置超时。可能需要通过Client对象获取HTTPConduit,并设置ReceiveTimeout和ConnectionTimeout。同时,注意异常处理,比如捕获可能的MalformedURLException或处理WSDL解析失败的情况。引用[4]提到了使用CXF的依赖,所以代码示例中需要包含正确的包引入。 还需要考虑代码的正确性,比如正确获取BindingProvider和SOAPBinding。可能用户会遇到的问题,比如超时设置无效,需要检查配置是否正确应用。最后,给出一个完整的示例,并提醒用户替换WSDL地址和相关参数。同时,可能建议如果频繁调用,考虑缓存客户端实例以提高性能,如引用[1]提到的生成代理类的开销。</think>### 分步解答:使用DynamicClientFactory创建Client并设置超时时间 #### 1. 创建动态客户端 通过`DynamicClientFactory`加载WSDL并创建客户端: ```java try { DynamicClientFactory dcf = DynamicClientFactory.newInstance(); Client client = dcf.createClient("http://example.com/service?wsdl"); } catch (MalformedURLException e) { // 处理WSDL地址格式错误 e.printStackTrace(); } catch (IOException e) { // 处理WSDL加载失败 e.printStackTrace(); } ``` 注意`createClient`方法内部会动态生成代理类[^1] #### 2. 配置超时参数 通过HTTPConduit设置连接和响应超时: ```java HTTPConduit conduit = (HTTPConduit) client.getConduit(); HTTPClientPolicy policy = new HTTPClientPolicy(); // 设置连接超时(单位:毫秒) policy.setConnectionTimeout(3000); // 设置接收响应超时 policy.setReceiveTimeout(10000); conduit.setClient(policy); ``` #### 3. 完整示例代码 ```java import org.apache.cxf.endpoint.Client; import org.apache.cxf.frontend.ClientProxy; import org.apache.cxf.transport.http.HTTPConduit; import org.apache.cxf.transports.http.configuration.HTTPClientPolicy; public class DynamicClientDemo { public static void main(String[] args) { try { // 创建动态客户端 DynamicClientFactory dcf = DynamicClientFactory.newInstance(); Client client = dcf.createClient("http://example.com/service?wsdl"); // 配置超时策略 HTTPConduit conduit = (HTTPConduit) client.getConduit(); HTTPClientPolicy policy = new HTTPClientPolicy(); policy.setConnectionTimeout(3000); // 3秒连接超时 policy.setReceiveTimeout(10000); // 10秒响应超时 conduit.setClient(policy); // 调用服务 Object[] result = client.invoke("operationName", new Object[]{param1, param2}); } catch (Exception e) { e.printStackTrace(); } } } ``` #### 关键注意事项: 1. **依赖配置**:需包含CXF核心依赖,如引用[4]中的`cxf-spring-boot-starter-jaxws` 2. **性能优化**:建议复用Client实例,避免重复创建的开销[^1] 3. **异常处理**: - `MalformedURLException`:检查WSDL地址格式 - `IOException`:检查网络连通性 4. **超时生效验证**:可通过模拟服务端延迟测试配置效果
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值