C# 使用WCF客户端进行web服务调用+;饼干
在C# 使用WCF客户端进行web服务调用+;饼干,c#,.net,wcf,authentication,cookies,C#,.net,Wcf,Authentication,Cookies,在WCF服务中实施基本安全身份验证。 设法从web服务获取.ASPXCookie。但是,如何将收到的cookie传递回下一个请求 var authClient = new MovieDbClient(); using (new OperationContextScope(authClient.InnerChannel)) { isValid = authClient.Login("userName", "passWord*"); if (isValid) {
WCF服务中实施基本安全身份验证。
设法从web服务获取.ASPXCookie
。但是,如何将收到的cookie传递回下一个请求
var authClient = new MovieDbClient();
using (new OperationContextScope(authClient.InnerChannel))
{
isValid = authClient.Login("userName", "passWord*");
if (isValid)
{
var response = (HttpResponseMessageProperty)OperationContext.Current.IncomingMessageProperties[HttpResponseMessageProperty.Name];
sharedCookie = response.Headers["Set-Cookie"];
}
}
我试着打印SharedCookie
,结果成功了。
看起来有点像
".ASPXAUTH=E499CA76EAC178A96BE5CA1E314CC90E0A6F9B95AD221EF5AD7D43598E701DC034D40904DBB8ECFBFB3EA21F2597D3C8DAB9B19A0491FD5858E9F0A4B6DC6E6A980FBB4CCADE191855A029CF8236C6890BEE28665C236992632807D1021AA138; expires=Tue, 07-Jan-2014 06:22:22 GMT; path=/; HttpOnly"
问题是在下一个请求中如何使用wCF Client-authClient
传递此cookie信息?在当前上下文中向wCF请求添加cookie头,前提是您已经拥有cookie字符串:
var prop = new HttpRequestMessageProperty();
prop.Headers.Add(HttpRequestHeader.Cookie, sharedCookie);
OperationContext.Current.OutgoingMessageProperties.Add(HttpRequestMessageProperty.Name, prop);
效果很好。就像一个符咒。非常感谢。请注意,Nicholas W的伟大解决方案只有在app.config ServiceModel的绑定中将标志“AllowCookies”设置为“true”时才有效!!!>