3

我的环境是一个带有spring boot的maven项目。我正在使用 wsimport 从 WSDL 生成 JAX-WS 代码。当我收到肥皂响应时,我想禁用肥皂验证。我正在使用 jdk8 的 jax-WS 的默认实现。代码如下所示:

// (1) 现在构建 webservice 客户端

MyWS_Service service = new MyWS_Service(null, new QName("http://...", "MyWS"));
MyWS port = service.getMyWSSOAP();

BindingProvider bindingProvider = (BindingProvider) port;

//(2) 禁用验证

       bindingProvider.getRequestContext().put("set-jaxb-validation-event-handler", "false");
// set endpoint
    bindingProvider.getRequestContext().put(BindingProvider.ENDPOINT_ADDRESS_PROPERTY, "http//...endpointaddress");

//(3) 执行请求

respObj = port.myRequest(myRequestObj);

我在谷歌搜索,我发现了一个禁用验证的选项:

(3) bindingProvider.getRequestContext().put("set-jaxb-validation-event-handler", sc.getSocketFactory());

但我似乎 jdk8 的 jax-WS 的默认实现不接受这个选项,但是它被 apache cxf 接受。那么,如何在 jdk8 的 jax-ws 的默认实现中停用验证?有没有办法在我的项目中加载 cxf 实现,所以我使用上一个选项来停用验证?有没有办法自定义 xml 验证?

4

1 回答 1

1

我没有找到禁用 jaxb xml 验证的解决方案,但我找到了一种将 apache cxf 集成到我的项目的方法,解决方案很简单,我只是将它添加到我的项目中

    <!--apache cxf implementation -->
    <dependency>
        <groupId>org.apache.cxf</groupId>
        <artifactId>cxf-rt-frontend-jaxws</artifactId>
        <version>${apache.cxf.version}</version>
    </dependency>
    <dependency>
        <groupId>org.apache.cxf</groupId>
        <artifactId>cxf-rt-transports-http</artifactId>
        <version>${apache.cxf.version}</version>
    </dependency>

我强制绑定提供程序禁用验证

bindingProvider.getRequestContext().put("set-jaxb-validation-event-handler", "false");

事实上,jdk 类javax.xml.ws.spi.FactoryFinder#find将在 CLASSPATH 中搜索javax.xml.ws.spi.Provider 文件的存在,如果不可用,则回退到默认的 Sun 实现。

我从这个链接中得到启发: force jax-ws apache cxf implementation

所以这些是所有步骤:

  1. 使用 wsimport 生成存根

  2. 将 cxf-rt-frontend-jaxws-*.jar 添加到类路径(通过 mvn 添加 cxf-rt-frontend-jaxws 工件)以强制 apache cxf 实现

  3. 禁用验证 bindingProvider.getRequestContext().put("set-jaxb-validation-event-handler", "false");

于 2019-03-20T13:53:50.147 回答