API end point returning “Authorization has been denied for this request.” when sending bearer token

前端 未结 3 1110
清酒与你
清酒与你 2021-02-04 05:08

I\'ve followed a tutorial to protect a Web API with OAuth in C#.

I\'m doing some tests and so far I\'ve been able to get the access token successfully from /token

相关标签:
3条回答
  • 2021-02-04 05:13

    Issue is pretty simple: Change order of your OWIN pipeline.

    public void Configuration(IAppBuilder app)
    {
        ConfigureOAuth(app);
        var config = new HttpConfiguration();
        WebApiConfig.Register(config);
        app.UseWebApi(config);
    }
    

    For OWIN pipeline order of your configuration quite important. In your case, you try to use your Web API handler before the OAuth handler. Inside of it, you validate your request, found you secure action and try to validate it against current Owin.Context.User. At this point this user not exist because its set from the token with OAuth Handler which called later.

    0 讨论(0)
  • 2021-02-04 05:22

    You have to add a claim with this schema:

    http://schemas.microsoft.com/ws/2008/06/identity/claims/role
    

    best thing to do is to use the pre-defined set of claims:

    identity.AddClaim(new Claim(ClaimTypes.Role, "User"));
    

    You can find ClaimTypes in System.Security.Claims.

    Another thing you have to consider is filter roles in your Controller/Action:

    [Authorize(Roles="User")]
    

    You can find a simple sample app, self-hosted owin with a jquery client here.

    0 讨论(0)
  • 2021-02-04 05:22

    Looks like the version of "System.IdentityModel.Tokens.Jwt" that co-exists with the other Owin assemblies is not proper.

    In case you're using "Microsoft.Owin.Security.Jwt" version 2.1.0, you ought to be using the "System.IdentityModel.Tokens.Jwt" assembly of version 3.0.2.

    From the package manager console, try:

    Update-Package System.IdentityModel.Tokens.Jwt -Version 3.0.2
    
    0 讨论(0)
提交回复
热议问题