java webservice怎么生成wsdl文件

java webservice怎么生成wsdl文件,第1张

在大多数情况下我们都需要为我们的服务提供一个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_06

Spring关于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

当然需要修改也可以实现


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/tougao/6055412.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-03-13
下一篇 2023-03-13

发表评论

登录后才能评论

评论列表(0条)

保存