Issuing and authenticating JWT tokens in ASP.NET Core WebAPI – Part II

Introduction

本文的例子是你如何使用ASP.NET Core 1来发行你的JWT tokens和通过简单的应用程序,自动控制对持有者的访问使用** [Authorize] **,特别关注基于用户声明授权使用ASP.NET Core MVC的策略特性在一个Web API项目中。

Part I 第一部分讨论了如何发布JWT,在本部分中,我们将介绍授权方面的。

因此,这篇文章的组织如下:

  1. Configuration – 解决需要添加到中间件和服务的问题,以便进行身份验证。
  2. You Shall Not Pass! 我不能帮助我自己,是的,访问控制。
  3. Quick Revision 我们将怎样到底那里。
  4. Authorise 设置一个控制器来测试这些东西。
  5. Testing– 实际上测试了这些东西。

Once again I wish to reiterate(重申) that, if you would like to go straight to(进入) production-ready(生产就绪) frameworks, both IdentityServer as well as OpenIddict are actively developed and maintained.(积极开发和维护)

Requirements

为了理解这篇文章,你很可能需要读第一部分。
however, if you would prefer just getting straight to the code(直接使用代码), you can download/fork(分叉) the example project and reference the relevant sections as we go.(并参考相关章节)

Configuration

首先,我们需要添加基于声明式的授权 claims-based authorisation策略。
This is easily done in the ConfigureServices method in Startup.cs

它所做的就是添加一个策略:DisneyUser,要求DisneyCharacter 声明在传入的token有效负载上有一个IAmMickey的值(稍后我会讲策略是如何应用的)

接下来要做的事,就是告诉ASP.NET,传入的请求会带JWT。幸运的是,有中间件支持(although(尽管) it does require that you add the Microsoft.AspNetCore.Authentication.JwtBearer package as a dependency)

Adding middleware is done in the Configure method of Startup.cs,因为这是在推动授权,它首先需要在中间件管道中添加,
in case(如果) you did not know this,** the order in which you add middlewareis important**

  • Lines 8 – 23:设置我们要传递的参数给ASP.NET'S JWT身份验证 中间件(可以有更多的选择在这里利用,以供参考:TokenValidationParameters live in the Microsoft.IdentityModel.Tokens namespace) I believe the parameters set in this example are reasonably self-explanatory(合理地,不言而喻的。)但是如果有什么不清楚的,请在评论中提问。
  • Lines 25 – 30: add the JWT token bearer(持有者) middleware that tells the application that we expect(希望) JWT tokens as part of the authentication(身份验证) and authorisation processes(授权验证) and to automatically challenge and authenticate.自动调整和验证)。

这就是配置,接下来,限制使用授权策略访问控制器。

You Shall(将) Not Pass!

Quick Revision(快速修测)
  • Part I,I set up claims identities in JwtController.cs and gave the user MickeyMouse, a claim named DisneyCharacter with the value IAmMickey (refer back to lines 110 – 134 of that file).

  • 在上面的Configuration部分中,, I added a DisneyUser authorisation (授权)policy to the services collection(服务集合).

Authorise(授权)

为了测试授权设置,我们需要一个能满足我们请求的服务器,为此,我创建了一个非常基本的JwtAuthTestController.

  • Line 7: 注意控制器的路由配置
  • Lines 20 – 32: 这是控制器中唯一的方法
  • Line 20: 告诉应用程序,该方法期望得到GET请求
  • Line 21: 告诉身份验证中间件把DisneyUser的授权策略用在该方法。这将确保只有满足我们在配置中设置的要求的JWT的持有者才可以访问这个方法
  • Lines 22 – 32: 在控制器中执行一些基本的逻辑并返回响应。
Testing

基本的测试设置和第一部分* Part I*的基本测试是一样的。为了便于参考,我重复这里的说明。

对于测试和验证部分,您需要有一些方法向应用程序发送请求,I am particular to Postman and will be using it throughout.

还有 55% 的精彩内容
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
支付 ¥2.99 继续阅读
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 200,783评论 5 472
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 84,396评论 2 377
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 147,834评论 0 333
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,036评论 1 272
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,035评论 5 362
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,242评论 1 278
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,727评论 3 393
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,376评论 0 255
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,508评论 1 294
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,415评论 2 317
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,463评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,140评论 3 316
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,734评论 3 303
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,809评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,028评论 1 255
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,521评论 2 346
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,119评论 2 341

推荐阅读更多精彩内容