在 .NET WebAPI 中,我创建了一种将所有授权规则放在一个中央位置的方法,而不是分散在各个控制器中。我很好奇为什么不经常进行这种集中化;是否有影响/安全问题?
我目前的方法是在 App_Start 期间创建一个字典,其中包含我的所有授权数据,然后使用 DelegatingHandler 来应用限制(下面的代码)。字典键是Controller和Action的元组,值是授权角色。DelegatingHandler 绑定到 WebAPI 的路由配置以获取调用哪个控制器,然后使用 Dictionary 来确定是否允许请求。
字典:
var authorizations = new Dictionary<Tuple<string, string>, string>();
authorizations.Add(new Tuple<string, string>("values", "get"), "public");
authorizations.Add(new Tuple<string, string>("values", "put"), "private");
委托处理程序:
public class SecurityDelegateHandler : DelegatingHandler
{
private readonly Dictionary<Tuple<string, string>, string> _authorizations;
public SecurityDelegateHandler(Dictionary<Tuple<string, string>, string> auth)
{
_authorizations = auth;
}
protected override Task<HttpResponseMessage> SendAsync(HttpRequestMessage request, CancellationToken cancellationToken)
{
var config = GlobalConfiguration.Configuration;
var controllerSelector = new DefaultHttpControllerSelector(config);
var descriptor = controllerSelector.SelectController(request);
string restrictions;
if (!_authorizations.TryGetValue(
new Tuple<string, string>(descriptor.ControllerName.ToLower(),
request.Method.ToString().ToLower()), out restrictions))
{
return Task<HttpResponseMessage>.Factory.StartNew(() =>
request.CreateResponse(HttpStatusCode.Forbidden,
"Access denied on unconfigured actions"),
cancellationToken);
}
if (!(Roles.Provider).GetRolesForUser(
HttpContext.Current.User.Identity.Name).Any(r =>
restrictions.Contains(r)))
{
return Task<HttpResponseMessage>.Factory.StartNew(() =>
request.CreateResponse(HttpStatusCode.Forbidden,
"Access Denied"), cancellationToken);
}
return base.SendAsync(request, cancellationToken);
}
}
总之,我的问题是:
- 以这种方式实施基于角色的授权有什么问题吗?
- 有没有什么好的包可以处理 WebAPI 的集中授权?我调查了 FluentSecurity,但似乎不支持 WebAPI。
谢谢!