2

我已经使用 Apache CXF 2.5.2 创建了一个 Web 服务端点,但是我在模式验证和 MTOM 交互方面遇到了一些问题。如果我启用 MTOM 和模式验证,我必须直接使用 base64Binary 类型,但是我试图符合一个固定规范,其中 MTOM 字段也具有“contentType”属性。

<jaxws:properties>
    <entry key="mtom-enabled" value="true"/>
    <entry key="schema-validation-enabled" value="true"/>
</jaxws:properties>

是否可以仅对入站或出站消息启用架构验证?例如:

<entry key="schema-validation-enabled" value="inbound"/>

或者,是否有其他方法可以实现这一点,例如覆盖出站消息验证?

谢谢。

4

1 回答 1

1

从 Apache CXF 3.0 开始,这是可能的。您不能在入站/出站的基础上禁用验证,但您可以有选择地忽略验证错误(因此您仍然会受到性能影响)。

您在 CXF 配置中配置读取器(入站)和写入器(出站)验证事件处理程序。

<jaxws:properties>
    <!-- Validation of the SOAP Message--> 
    <entry key="schema-validation-enabled" value="true" />

    <entry key="jaxb-reader-validation-event-handler">
        <bean class="com.example.cxf.InboundValidationEventHandler" />
    </entry>

    <entry key="jaxb-writer-validation-event-handler">
        <bean class="com.example.cxf.OutboundValidationEventHandler" />
    </entry>
</jaxws:properties>

创建ValidationEventHandlers这样的并返回true。返回true通知 CXF 忽略单个验证错误并继续验证。

package com.example.cxf;

import javax.xml.bind.ValidationEvent;
import javax.xml.bind.ValidationEventHandler;

public class InboundValidationEventHandler implements ValidationEventHandler {

    public boolean handleEvent(ValidationEvent event) {
        String message = event.getMessage();
        Throwable t = event.getLinkedException();

        System.out.println("Ignoring Inbound Validation EVENT : " +  message);

        // ignore
        return true;
    }
}
于 2014-06-11T01:22:03.823 回答