【发布时间】:2014-11-18 14:53:19
【问题描述】:
我们正在使用 spring-ws 2.2.0 开发一个契约优先的 WebService。我们正在尝试使用位于 SoapHeader 中的名为 AuthToken 的自定义标签来管理身份验证。
AuthToken 具有以下结构:
<authToken>
<username>USERNAME</xa:username>
<password>PASSWORD</xa:password>
</authToken>
我们能够在 SoapHeader 中生成包含指定自定义身份验证标记的 WSDL 模式。 问题是当客户端向我们的服务器执行调用时,我们无法在 Ws Endpoint 实现中解组 AuthToken 标记(位于 SoapHeader 中)。
使用绑定方法签名中的@RequestPayload 注解(handleMethodRequest,如下例所示),我们能够访问未编组的有效负载内容(位于 SoapBody 中)。
我们试图用 SoapHeader 内容做同样的事情,但没有成功。
在以下代码示例中,我们向您展示了我们想要获得的内容:
1
@PayloadRoot(namespace = NAMESPACE_URI, localPart = "methodRequest")
@ResponsePayload
public MethodResponse handleMethodRequest(@RequestPayload MethodRequest request, @SoapHeader(value = "authToken") AuthToken authToken) { }
2
@PayloadRoot(namespace = NAMESPACE_URI, localPart = "methodRequest")
@ResponsePayload
public MethodResponse handleMethodRequest(@RequestPayload MethodRequest request, AuthToken authToken) { }
3
@PayloadRoot(namespace = NAMESPACE_URI, localPart = "methodRequest")
@ResponsePayload
public MethodResponse handleMethodRequest(@RequestPayload MethodRequest request, org.springframework.ws.soap.SoapHeader header) { }
4
@PayloadRoot(namespace = NAMESPACE_URI, localPart = "methodRequest")
@ResponsePayload
public MethodResponse handleMethodRequest(@RequestPayload MethodRequest request, MessageContext messageContext) { }
在情况 1、2 中我们得到以下错误:
No adapter for endpoint [MethodResponse EndpointImplementation.handleMethodRequest(MethodRequest, AuthToken) throws java.lang.Exception]: Is your endpoint annotated with @Endpoint, or does it implement a supported interface like MessageHandler or PayloadEndpoint?
在情况 3、4 中我们没有错误,但我们无法处理 SoapHeader 或 MessageContext(分别在情况 3 和 4 中)以达到我们的目的,访问 AuthToken 以检索用户名和密码子元素。
在网上寻找解决方案时,我们发现很多人遇到同样的问题时使用 Spring 拦截器来处理身份验证。
按照“拦截器方式”,我们应该访问拦截器内的AuthToken。不幸的是,我们需要将 handleMethodRequest 方法中的 AuthToken 字段用于其他目的,例如加载用户特定的数据,在 handleMethodRequest 之外无法访问。
因此我们不能遵循这种方式,因为我们需要在 handleMethodRequest 方法中引用用户特定的数据。
有谁知道我们该如何解决这个问题?提前致谢。
【问题讨论】:
标签: spring web-services spring-ws soapheader