一般分为静态调用和动态调用
静态调用就是在项目中直接添加服务引用或者web服务引用;
动态调用就是通过模拟http协议调用,这种网上很多提供动态调用服务的处理类,你找找直接用就可以了;
静态调用特点:服务参数包含复杂类型(比如自定义的一些实体类)用它比较方便,但是服务如果改变(服务地址更新,服务内容更新)就需要在项目中更新服务引用,重新编译程序;
动态调用特点:对于服务参数包含复杂类型.
来一盘地三鲜关注
axis1.4 设置请求超时时间 原创
2014-03-23 11:03:55
来一盘地三鲜
码龄15年
关注
项目中使用axis1.4生成的webservice,访问公安网的接口,使用过程中某些业务和时间段调用接口会产生请求超时的情况,由于业务是顺序执行,无法通过线程等待一段时间的方式来处理请求超时,因此只能尝试从webservice自身入手。
先说解决方案:通过各种设置setTimeout来控制请求超时时间。
具体怎么设置,尝试过的有如下几种:
如果是使用stub方式调用webservice,有两种方式设定:
1:统一所有出口的超时时间设定:
这种方式在axis生成的四个客户端类中,对stub这个类下手,这个类就是stub方式调用的核心类,以前总认为它是自动生成能的,不能随便乱动,其实不然,关键是找到下手的地方。仔细阅读,你会在这个类里面找到webservice服务端对外暴露的方法,然后在在该方法里面找到生成call对象的地方,加入如下一行代码即可:
_call.setTimeOut(30000) //单位是毫秒
如果你想更灵活的控制超时时间,不妨把控制时间设置到配置文件里。
2:单个方法的超时时间控制:
在你的业务类处理接口调用方法里面,在获得stub对象的下面,加入如下代码:
stub.setTimeOut(30000) //单位是毫秒
这种方案控制到了具体的某个方法,更灵活。
解决方案来自于这里:
http://axis.apache.org/axis/faq.html#faq17
如果你是使用便捷模式调用,那更简单,直接一句话(标红代码):
String endpoint="http://ip/project/services/xxx?wsdl"
Service service =new service()
Call call=(Call) service.createCall()
call.setTargetEndpointAddress(endpoint)
call.setOperationName("methodname")
call.setTimeout(10000) //单位是毫秒
String ret =(String)call.invoke(new Object[] {xmldoc})
这种方法简单便捷,对于测试webservice极为方便,但是缺少灵活性,工程一般不建议使用。
最重要的,所有的方案都是从客户端下手,因为服务端常常不是你所能控制的。
总结:
1:要保持英文阅读的能力,不然就算有解决方案都看不懂。
2:不要人云亦云:其实long long ago,在网上就查到过通过设置setTimeout参数来控制超时时间的观点,但是好多人都说这个参数设置无效,当时也没有深入,只是人云亦云的想当然,大多数人的悲哀,挣扎吧,少年。
3:经验是一个不断积累的过程,也只有经验积累到了一定程度,娴熟了,才会有庖丁解牛的勇气和行动。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)