在javaEE6的bin文件夹时,有一个wsimport.exe,这个工具在5.0之前的版本里是没有的,这个工具依据wsdl文件生成相应的类文件,然后用这些类文件,就可以像调用本地的类一样调用WebService提供的方法了
- wsimport工具详细参数
The wsimport
tool generates JAX-WS portable artifacts,such as:
- Service Endpoint Interface (SEI)
- Service
- Exception class mapped from wsdl:fault (if any)
- Async Reponse Bean derived from response wsdl:message (if any)
- JAXB generated value types (mapped java classes from schema types)
These artifacts can be packaged in a WAR file with the WSDL and schema documents along with the endpoint implementation to be deployed. The generated Service class can be used to invoke the Web Service endpoint.
wsimport [options] <wsdl>
Option |
Description |
---|---|
|
Specify where to place generated output files |
|
Specify external JAX-WS or JAXB binding files (Each |
-catalog |
Specify catalog file to resolve external entity references,it supports TR9401,XCatalog,and oasis XML Catalog format. Please read the XML Entity and URI Resolvers document or seewsimport_catalog sample. |
|
allow vendor extensions (functionality not specified by the specification). Use of extensions may result in applications that are not portable or may not interoperate with other implementations |
|
display help |
|
Specify an HTTP proxy server (port defaults to 8080) |
|
Keep generated files |
-p |
Specifying a target package via this command-line option,overrides any wsdl and schema binding customization for package name and the default package name algorithm defined in the specification |
|
Specify where to place generated source files |
|
Output messages about what the compiler is doing |
|
Print version @R_315_4045@ion |
-wsdllocation <location> |
@WebService.wsdlLocation and @WebServiceClient.wsdlLocation value |
- wsimport工具用法实例
首先,须保证你的jdk为6.0以上版本,可以在command line下试运行这个命令
c:\test> wsimport
假设我们有下面的wsdl文件
http://localhost:9080/WebService/TestService/TestService.wsdl
我们要把生成的代码放到c:/test/com.bjmaxinfo.rpc.merchantware.ws目录下,那么我们运行以下命令即可
c:\test> wsimport -p com.bjmaxinfo.rpc.merchantware.ws -keep http://localhost:9080/WebService/TestService/TestService.wsdl
然后,你就会看到在c:\test\generate目录下生成了一些java代码文件,wsimport就是如此简单
- 编写调用WebService的客户端
假如我们要调用的WebService就是之前举例提到的TestService,它只有下面这样一个方法
- public String test(String name) throws SOAPException
- {
- if (name == null)
- {
- throw new SOAPException("name can't be null!");
- }
- return "hello " + name;
- }
generate
|--com
|--company
|--ObjectFactory.java
|--SOAPException.java
|--SOAPException_Exception.java
|--Test.java
|--TestResponse.java
|--TestService.java
|--TestService_Service.java
|--package-info.java
把它们编译,然后写下面这样一个application去测试
运行它,屏幕就会输出
name can't be null
因为我们之前传了一个null值进去嘛,其实这也是为了测试SOAPException是否正常运行,如果你传个正确的字符串进去,webservice就可以正常运行,如System.out.println(service.test("javaeye"));,屏幕上就会显示,
Hello javaeye!
顺便提一下WebService的异常处理,所有WebService的异常都必须用SOAPException抛出,它是java.xml.soap包中的一个类 (本人试过其它一些Exception,都不能被正常捕捉,只有SOAPException可以正常工作,具体原因不明,如果有哪个人清楚这一点,请评论告之,谢谢)
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。