小编alb*_*olo的帖子

如何在Asp.net Web Api 2中获取自定义声明值 - Owin - ApiController.

我使用此代码创建了一些声明,我在登录应用程序时获取了值.我想在我的一些api控制器中使用"Id"的声明值,

var identity = new ClaimsIdentity(context.Options.AuthenticationType);

var props = new AuthenticationProperties(new Dictionary<string, string>
{
    { "UserName", customer.FirstName }, { "Id", customer.Id.ToString() } 
});
Run Code Online (Sandbox Code Playgroud)

var ticket = new AuthenticationTicket(identity,props); context.Validated(票);

所以在控制器中我有这个代码:

[Authorize]
[Route("api/banners/{customerId")]
[HttpGet]
public HttpResponseMessage GetBanners(int customerId)
{
    return Request.CreateResponse<IEnumerable<Banner>>(HttpStatusCode.OK, AppDataAccess.GetBanners(customerId)));
}
Run Code Online (Sandbox Code Playgroud)

我想将代码更改为此代码:

[Authorize]
[Route("api/banners")]
[HttpGet]
public HttpResponseMessage GetBanners()
{ 
   int CustomerId =  SOME FUNCTION THAT GETS THE CLAIM VALUE I WANT (ID)

    return Request.CreateResponse<IEnumerable<Banner>>(HttpStatusCode.OK, AppDataAccess.GetBanners(customerId)));
}
Run Code Online (Sandbox Code Playgroud)

我一直在研究,但我刚刚找到了AuthorizationFilterAttribute,但它只是在路由上使用它,有没有什么方法你知道我可以构建该功能所以我只是在控制器中调用它?

我正在使用Microsoft.AspNet.Identity.Owin 2.0.0

谢谢您的帮助

claims-based-identity asp.net-web-api2 asp.net-identity-2

3
推荐指数
1
解决办法
4508
查看次数

如何使用Asp.net WebApi验证离子应用程序

我有一个asp.net web api,它已被一个离子应用程序使用.
这个web api有一些需要授权的路由,有些则没有.

无论如何配置web api只是为了被离子应用程序消费?任何帮助,将不胜感激.

谢谢

asp.net-web-api ionic-framework ionic

2
推荐指数
1
解决办法
4526
查看次数