windows下使用cmd命令提示符生成java webservice客户端代码,可以使用命令提示符直接生成客户端代码,直接导入到项目中,只需配置jdk即可,在jdk的bin文件夹下,按shift并点击右键,选中“在此处打开命令窗口”
输入命令如下:
1
|
wsimport -keep -p com.demo.client -d d:\\(存放的地址) http: //xx/account?wsdl(wsdl地址) |
命令参数说明:
-d:生成客户端执行类的class文件的存放目录(默认存放在c:\users\administrator\)
-s:生成客户端执行类的源文件的存放目录(默认存放在c:\users\administrator\)
-p:定义生成类的包名
图示:
上面代码是在d盘下生成java代码,-d代表的是生成class文件和java文件,图示:
如果把这里的-d改为-s,生成的只有java文件,图示:
文件里面包名都是我们可以指定的,如果没有指定,使用的就是根据wsdl文档里面的targetnamespace来命名。
共勉:这个时代会犒赏那些爱学习的人。
补充:利用wsdl地址生成java客户端调用类并实现动态配置的方法
前言:
有时,我们经常要和一些外部系统对接,如果是http接口还好,直接用apache的httpclient工具类调用即可。而如果对方系统是webservice,则比较麻烦,本文主要讲解如何用对方的wsdl地址生成java客户端调用类并且动态配置访问地址并在java中使用
1,首先我们先要获取对方的wsdl地址,例如
1
|
http: //xxxx/xxxx/xxxx.asmx?wsdl |
2, 接着,在cxf官网上下载apache-cxf-3.2.5
2.1,将apache-cxf-3.2.5解压缩后安装在d:\\apache-cxf-3.2.5中,设置cxf_home环境变量为d:\\ apache-cxf-3.2.5
如下图所示:
2.2,运行cmd,执行命令wsdl2java,等待大概1秒钟,出现usage证明设置成功
2.3,用wsdl地址执行命令:其中-d代表输出路径,后面紧跟着路径,路径后面紧跟着地址,按回车键,生成成功!
3,生成成功后
由于wsdl是写死在生成的java类的注解中的,有时我们会使用多套环境进行测试,验证,而sit和uat环境的wsdl地址是不尽相同的。此时,我们需要动态配置wsdl的地址和命名空间的地址
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
|
@component public class debitpushclient implements initializingbean { private static url wsdlurl; private static string debitwsdlurl; private static string uri; private static qname service_name; public static httpresult pushdebitdata(string jsondata) { financialsharing ss = new financialsharing(wsdlurl, service_name); return (httpresult) webserviceclientutil.invokewebservicesoapaction(ss, new qname(uri, "financialsharingsoap12" ), financialsharingsoap. class , "pushdebitdata" , jsondata); } /** * 初始化wsdl连接地址 */ private void initwsdlurl() { url url = null ; try { wsdlurl = new url(debitwsdlurl); } catch (malformedurlexception e) { java.util.logging.logger.getlogger(financialsharing. class .getname()) .log(java.util.logging.level.info, "can not initialize the default wsdl from {}" , debitwsdlurl); } } /** * 从配置文件中读取wsdl地址 * @param debitwsdlurl 地址 */ @value ( "${my.dfdk.wsdl.url:http://xxx.xxx.asmx?wsdl}" ) public void setdebitwsdlurl(string debitwsdlurl) { debitpushclient.debitwsdlurl = debitwsdlurl; } /** * 从配置文件中读取命名空间地址 * @param uri 命名空间地址 */ @value ( "${my.dfdk.wsdl.namespace.uri:http://tempuri.org/}" ) public void seturi(string uri) { debitpushclient.uri = uri; } /** * 初始化wsdl * @throws exception */ @override public void afterpropertiesset() throws exception { initwsdlurl(); service_name = new qname(uri, "financialsharing" ); } } |
4,客户端调用,调用成功后,即可获取正确的响应结果,不需要再将xml转成java对象
这篇文章,只是简单介绍了用wsdl地址生成java客户端调用代码的一种方法,除此之外,还可以用maven plugin
cxf-codegen-plugin
生成
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
|
<build> <finalname>cxf-date</finalname> <plugins> <plugin> <groupid>org.apache.cxf</groupid> <artifactid>cxf-codegen-plugin</artifactid> <version>${cxf.version}</version> <executions> <execution> <id>generate-sources</id> <phase>generate-sources</phase> <configuration> <sourceroot>src/main/resources/cxf</sourceroot> <wsdloptions> <wsdloption> <wsdl>http: //localhost:8080/cxf-date/services/bookservice?wsdl</wsdl> <frontend>jaxws21</frontend> <faultserialversionuid> 1 </faultserialversionuid> </wsdloption> </wsdloptions> </configuration> <goals> <goal>wsdl2java</goal> </goals> </execution> </executions> </plugin> </plugins> </build> |
以上为个人经验,希望能给大家一个参考,也希望大家多多支持服务器之家。如有错误或未考虑完全的地方,望不吝赐教。
原文链接:https://blog.csdn.net/wenzhi20102321/article/details/68484354