场景是使用 Wcf 服务和自定义身份验证的 Silverlight 客户端。为了缓解 500/200 状态代码问题(避免 EndPointNotFound 异常),我应用了SilverLightFaultBehaviour。但是,这不适用于UserNamePasswordValidator - 当从 Validate() 引发 FaultException 时,SilverLightFaultMessageInspector 的 BeforeSendReply 实现不会捕获它。
到目前为止,我发现的唯一解决方法是使用替代客户端堆栈WebRequest.RegisterPrefix("http://", WebRequestCreator.ClientHttp);
(Silverlight 5 - 调试 npctrl.dll 崩溃,http://communities.vmware.com/thread/394306 ?tstart=0 )。
我的主要动机是我希望能够区分登录失败和连接错误(以下代码来自客户端异步回调方法,仅适用于客户端堆栈):
if (e.Error is MessageSecurityException)
{
this.HasLoginFailed.Value = Captions.Login_FailedLogin;
}
else
{
this.HasLoginFailed.Value = Captions.Login_FailedConnection;
}
从 UserNamePasswordValidator 抛出 FaultException 时,是否有其他方法可以修改发送的消息?或者任何概念上不同的自定义身份验证方式,而不是我正在使用的方式,它使我能够修改消息状态或将其保持为 200,或者只是能够区分连接失败和错误凭据?
我的用户名密码注册服务器端代码:
var serviceCredential = host.Description.Behaviors.Find<ServiceCredentials>();
serviceCredential.UserNameAuthentication.UserNamePasswordValidationMode =
UserNamePasswordValidationMode.Custom;
serviceCredential.UserNameAuthentication.CustomUserNamePasswordValidator =
new MyValidator();