在大多数情况下我们都需要为我们的服务提供一个WSDL
文件,而 Axis2's Java2WSDL 是专门用来生成WSDL文件的D专用工具,如果你要在命令行模式下进行生成WSDL文件,首先需要保证
你的环境变量AXIS2_HOME是否已经配置OK,同时还要保证把%AXIS2_HOME%\bin加入到你的path环境中,要生成 WSDL文件,首先要保证你的class能够编译成功,而且已经编译成功,然后进入class文件编译后的根目录(在JBuilder中是classes,在Eclipse中是bin目录)这时,生成WSDL文件的准备工作已经OK。\x0d\x0a\x0d\x0a下面是生成WSDL文件时的可选参数和参数说明:\x0d\x0a---------------------------------------------------------------------------------\x0d\x0aUsage java2wsdl -cn : class file name\x0d\x0a-o : output file location\x0d\x0a\x0d\x0a-cp : list of classpath entries - (urls)\x0d\x0a\x0d\x0a-tn : target namespace\x0d\x0a\x0d\x0a-tp : target namespace prefix\x0d\x0a\x0d\x0a-stn : target namespace for schema\x0d\x0a\x0d\x0a-stp : target namespace prefix for schema\x0d\x0a\x0d\x0a-sn : service name\x0d\x0a\x0d\x0a-of : output file name for the WSDL\x0d\x0a\x0d\x0a-st : style for the WSDL\x0d\x0a\x0d\x0a-u : use for the WSDL\x0d\x0a\x0d\x0a-l : address of the port for the WSDL\x0d\x0a\x0d\x0a-nsg : fully qualified name of the class that implements NamespaceGenerator\x0d\x0a\x0d\x0a-p2n [,,] ...\x0d\x0a\x0d\x0a-efd : Setting for elementFormDefault (defaults to qualified)\x0d\x0a\x0d\x0a-afd : Setting for attributeFormDefault (defaults to qualified)\x0d\x0a\x0d\x0a-xc : Extra class for which schematype must be generated.\x0d\x0aUse as : -xc class1 -xc class2 ...\x0d\x0a\x0d\x0a\x0d\x0a\x0d\x0a\x0d\x0a\x0d\x0a典型地,进入你的工程的二进制编译根目录,执行命令模板如下:\x0d\x0ajava2wsdl -cp . -cn [PACKAGENAME].[CLASSNAME]-of [FILENAME].wsdl\x0d\x0a\x0d\x0a现在我们假设在samples.helloworld.service.axiom包下面有个HelloWorldService类,工程的类文件编译后存放在build\classes目录下,那么,首先进入该目录中,然后执行以下命令:\x0d\x0ajava2wsdl -cp . -cn samples.helloworld.service.axiom.HelloWorldService -of HelloWorldService.wsdl\x0d\x0a\x0d\x0a执行后的CMD提示如下说明已经成功执行了:\x0d\x0a\x0d\x0aUsing AXIS2_HOME: D:\axis2-1.1.1\x0d\x0aUsing JAVA_HOME:C:\Program Files\Java\jdk1.5.0_06Spring关于webservice的框架
可以实现配置化自动生成wsdl文件与基于注解的自动序列化和反序列化
出现的问题:
1、想利用自动生成正确的wsdl文件
满足条件:默认的请求与响应的结尾Request与Response
Spring一贯的约定大于配置,约定的soap请求报文需要以Request结尾,soap响应报文需要以Response结尾,这是在给的spring-ws中硬编码实现的
如果想生成自定义的soap报文格式需要重写覆盖spring-ws的默认配置 DefaultWsdl11Definition
同时重写SuffixBasedMessagesProvider与SuffixBasedPortTypesProvider,关于后缀的问题
配置类
@EnableWs
@Configuration
public class WebServiceConfig {
@Bean(name ="Invoke")
public Wsdl11Definition defaultWsdl11Definition(XsdSchema srmSchema) {
//未解决默认请求后缀为Request才能正确生成wsdl文件的问题,
// 重写WSDL生成的实现类,覆盖默认的DefaultWsdl11Definition
//总体在于xml关键标签元素的渲染判断
MyWsdl11Definition definition =new MyWsdl11Definition()
definition.setPortTypeName("InvokePort")
definition.setTargetNamespace(Constant.NAMESPACE_BOI)
definition.setLocationUri("/ws")
definition.setSchema(srmSchema)
definition.setRequestSuffix("")//后缀修改,可以为空,而不是默认的Request
return definition
}
}
2. 访问spring-ws的wsdl,默认url.wsdl而不是习惯用的url?wsdl
当然需要修改也可以实现
评论列表(0条)