首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >WCF ServiceAuthenticationManager可扩展性

WCF ServiceAuthenticationManager可扩展性
EN

Stack Overflow用户
提问于 2017-12-14 16:22:54
回答 1查看 218关注 0票数 1

我想实现我的自定义安全到wcf,我想使用ServiceAuthenticationManager,但我不明白它如何可以阻止消息。我试图抛出异常,但我不能得到我的异常详细信息我得到的只是“请求错误”在rest调用和“调用者没有被服务验证”在soap调用,但我不能得到我的自定义错误信息,ServiceAuthenticationManager的正确用法是什么,或者我应该阻止消息?

代码语言:javascript
复制
public class MyAuthenticationManager :  ServiceAuthenticationManager
{
    public override ReadOnlyCollection<IAuthorizationPolicy> Authenticate(ReadOnlyCollection<IAuthorizationPolicy> authPolicy, Uri listenUri, ref Message message)
    {
        //throw new AuthenticationException("Credentials expired!");
        throw new SecurityException("my custom message:Invalid authentication");
        return base.Authenticate(authPolicy, listenUri,ref message);
    }
}
EN

回答 1

Stack Overflow用户

发布于 2017-12-14 17:51:13

身份验证/授权不提供自定义消息。任何你没有被授权或验证的迹象都是攻击者破解你的安全或获取他无权获得的信息的一种方式。

例如,说“您的密码是错误的”就表示用户名存在。那是很糟糕的。未经授权的请求永远不应获得此类信息作为响应。

如果您想查看哪里出了问题,请写入服务器管理员可以访问的日志。但不要向客户发送任何内容。永远不会。

所以总结一下:不,你不能得到一个自定义消息,这个设计是故意的。

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/47808804

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档