我使用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"/>
或者是否有另一种方法可以实现此目的,例如覆盖出站消息验证?
感谢。
答案 0 :(得分:1)
自Apache CXF 3.0以来,这是有可能的。您无法在进/出的基础上禁用验证,但您可以有选择地忽略验证错误(因此您仍然会受到性能影响)。
您配置阅读器(入站)&amp; CXF配置中的writer(出站)验证事件处理程序。
<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;
}
}