最新公告
  • 欢迎您光临起源地模板网,本站秉承服务宗旨 履行“站长”责任,销售只是起点 服务永无止境!立即加入钻石VIP
  • webservice通过wsdl生成客户端代码的几种实现方式

    正文概述 掘金(hao本尊36779)   2021-07-26   852

    网上的一个 wsdl可以根据这个案例去测试代码生成

    <?xml version='1.0' encoding='UTF-8'?><wsdl:definitions name="HelloWorldService" targetNamespace="http://test.demo1/" xmlns:ns1="http://schemas.xmlsoap.org/soap/http" xmlns:soap="http://schemas.xmlsoap.org/wsdl/soap/" xmlns:tns="http://test.demo1/" xmlns:wsdl="http://schemas.xmlsoap.org/wsdl/" xmlns:xsd="http://www.w3.org/2001/XMLSchema">
        <wsdl:types>
            <xs:schema elementFormDefault="unqualified" targetNamespace="http://test.demo1/" version="1.0" xmlns:tns="http://test.demo1/" xmlns:xs="http://www.w3.org/2001/XMLSchema">
                <xs:element name="sayHello" type="tns:sayHello"/>
                <xs:element name="sayHelloResponse" type="tns:sayHelloResponse"/>
                <xs:complexType name="sayHello">
                    <xs:sequence>
                        <xs:element minOccurs="0" name="arg0" type="xs:string"/>
                    </xs:sequence>
                </xs:complexType>
                <xs:complexType name="sayHelloResponse">
                    <xs:sequence>
                        <xs:element minOccurs="0" name="return" type="xs:string"/>
                    </xs:sequence>
                </xs:complexType>
            </xs:schema>
        </wsdl:types>
        <wsdl:message name="sayHelloResponse">
            <wsdl:part element="tns:sayHelloResponse" name="parameters">
            </wsdl:part>
        </wsdl:message>
        <wsdl:message name="sayHello">
            <wsdl:part element="tns:sayHello" name="parameters">
            </wsdl:part>
        </wsdl:message>
        <wsdl:portType name="HelloWorld">
            <wsdl:operation name="sayHello">
                <wsdl:input message="tns:sayHello" name="sayHello">
                </wsdl:input>
                <wsdl:output message="tns:sayHelloResponse" name="sayHelloResponse">
                </wsdl:output>
            </wsdl:operation>
        </wsdl:portType>
        <wsdl:binding name="HelloWorldServiceSoapBinding" type="tns:HelloWorld">
            <soap:binding style="document" transport="http://schemas.xmlsoap.org/soap/http"/>
            <wsdl:operation name="sayHello">
                <soap:operation soapAction="" style="document"/>
                <wsdl:input name="sayHello">
                    <soap:body use="literal"/>
                </wsdl:input>
                <wsdl:output name="sayHelloResponse">
                    <soap:body use="literal"/>
                </wsdl:output>
            </wsdl:operation>
        </wsdl:binding>
        <wsdl:service name="HelloWorldService">
            <wsdl:port binding="tns:HelloWorldServiceSoapBinding" name="HelloWorldPort">
                <soap:address location="http://localhost:8080/helloWorld"/>
            </wsdl:port>
        </wsdl:service>
    </wsdl:definitions>
    

    1、jdk自带的方式wsimport

    用法: wsimport [options] <WSDL_URI>
    
    \其中 [options] 包括:
      -b <path>                 指定 jaxws/jaxb 绑定文件或附加模式
                                (每个 <path> 都必须具有自己的 -b)
      -B<jaxbOption>            将此选项传递给 JAXB 模式编译器
      -catalog <file>           指定用于解析外部实体引用的目录文件
                                支持 TR9401, XCatalog 和 OASIS XML 目录格式。
      -d <directory>            指定放置生成的输出文件的位置
      -encoding <encoding>      指定源文件所使用的字符编码
      -extension                允许供应商扩展 - 不按规范
                                指定功能。使用扩展可能会
                                导致应用程序不可移植或
                                无法与其他实现进行互操作
      -help                     显示帮助
      -httpproxy:<host>:<port>  指定 HTTP 代理服务器 (端口默认为 8080)
      -keep                     保留生成的文件
      -p <pkg>                  指定目标程序包
      -quiet                    隐藏 wsimport 输出
      -s <directory>            指定放置生成的源文件的位置
      -target <version>         按给定的 JAXWS 规范版本生成代码
                                默认为 2.2, 接受的值为 2.0, 2.1 和 2.2
                                例如, 2.0 将为 JAXWS 2.0 规范生成兼容的代码
      -verbose                  有关编译器在执行什么操作的输出消息
      -version                  输出版本信息
      -wsdllocation <location>  @WebServiceClient.wsdlLocation 值
      -clientjar <jarfile>      创建生成的 Artifact 的 jar 文件以及
                                调用 Web 服务所需的 WSDL 元数据。
      -generateJWS              生成存根 JWS 实现文件
      -implDestDir <directory>  指定生成 JWS 实现文件的位置
      -implServiceName <name>   生成的 JWS 实现的服务名的本地部分
      -implPortName <name>      生成的 JWS 实现的端口名的本地部分
    
    \扩展:
      -XadditionalHeaders              映射标头不绑定到请求或响应消息不绑定到
                                       Java 方法参数
      -Xauthfile                       用于传送以下格式的授权信息的文件:
                                       http://username:password@example.org/stock?wsdl
      -Xdebug                          输出调试信息
      -Xno-addressing-databinding      允许 W3C EndpointReferenceType 到 Java 的绑定
      -Xnocompile                      不编译生成的 Java 文件
      -XdisableAuthenticator           禁用由 JAX-WS RI 使用的验证程序,
                                       将忽略 -Xauthfile 选项 (如果设置)
      -XdisableSSLHostnameVerification 在提取 wsdl 时禁用 SSL 主机名
                                       验证
    
    \示例:
      wsimport stock.wsdl -b stock.xml -b stock.xjb
      wsimport -d generated http://example.org/stock?wsdl
    

    2、Apache-cxf的wsdl2java方式

    1. Apache CXF 下载 一般选择 Binary distribution 的就可以

    webservice通过wsdl生成客户端代码的几种实现方式

    1. 下载后解压到指定目录

      E:\service\webservice\apache-cxf-3.3.11
      

    webservice通过wsdl生成客户端代码的几种实现方式

    1. apache-cxf-*/bin目录加入到系统变量path

      E:\service\webservice\apache-cxf-3.3.11\bin
      

      webservice通过wsdl生成客户端代码的几种实现方式

    2. CMD命令输入 wsdl2java -help 测试是否正常

    webservice通过wsdl生成客户端代码的几种实现方式

    1. 在解压的目录 apache-cxf-*/bin下执行wsdl2java命令

      webservice通过wsdl生成客户端代码的几种实现方式

      webservice通过wsdl生成客户端代码的几种实现方式

      wsdl2java -encoding utf-8 -d 生成文件的目录 wsdl文件地址或wsdl url地址

      PS E:\service\webservice\apache-cxf-3.3.11\bin> wsdl2java -encoding utf-8 -p com.example.order -d D:\ideaProject\htlm\demo\web-service-demo\src\main\java D:\ideaProject\htlm\demo\web-service-demo\src\main\resources\Air.wsdl
      
       用法: wsdl2java [options] <WSDL_URI>
       
       \其中 [options] 包括:
       -p <[wsdl-namespace =]package-name>*    指定生成的代码要使用的 java 包名称
       -d <output-directory>                   指定放置生成的目录
       -server                                 指定生成服务端代码
       -client                                 指定生成客户端代码
       -autoNameResolution                     指定该工具将尝试解决类的命名冲突,而不要求使用绑定定制。
       \示例:
         wsdl2java -d D:\demo D:\t.wsdl
    

    3、IDEA自带插件生成

    1. idea菜单栏选择Tools->WebServices->Generate Java Code From Wsdl

      webservice通过wsdl生成客户端代码的几种实现方式

    常见问题

    1. IDEA生成代码时,如果使用的jdk11编译的项目,可能会出现如下错误, 请使用jdk8。或者使用第二种生成方式

    webservice通过wsdl生成客户端代码的几种实现方式

    1. 提示 具有相同名称 的类/接口已在使用。请使用类定制设置来解决此冲突

      以第二种生成方式为例, 只要在命令中添加 -autoNameResolution参数即可

      wsdl2java -autoNameResolution -d D:\demo D:\t.wsdl
      

    起源地下载网 » webservice通过wsdl生成客户端代码的几种实现方式

    常见问题FAQ

    免费下载或者VIP会员专享资源能否直接商用?
    本站所有资源版权均属于原作者所有,这里所提供资源均只能用于参考学习用,请勿直接商用。若由于商用引起版权纠纷,一切责任均由使用者承担。更多说明请参考 VIP介绍。
    提示下载完但解压或打开不了?
    最常见的情况是下载不完整: 可对比下载完压缩包的与网盘上的容量,若小于网盘提示的容量则是这个原因。这是浏览器下载的bug,建议用百度网盘软件或迅雷下载。若排除这种情况,可在对应资源底部留言,或 联络我们.。
    找不到素材资源介绍文章里的示例图片?
    对于PPT,KEY,Mockups,APP,网页模版等类型的素材,文章内用于介绍的图片通常并不包含在对应可供下载素材包内。这些相关商业图片需另外购买,且本站不负责(也没有办法)找到出处。 同样地一些字体文件也是这种情况,但部分素材会在素材包内有一份字体下载链接清单。
    模板不会安装或需要功能定制以及二次开发?
    请QQ联系我们

    发表评论

    还没有评论,快来抢沙发吧!

    如需帝国cms功能定制以及二次开发请联系我们

    联系作者

    请选择支付方式

    ×
    迅虎支付宝
    迅虎微信
    支付宝当面付
    余额支付
    ×
    微信扫码支付 0 元