基于JWT(Json Web Token)的ASP.NET Web API授权方式

token应用流程

初次登录:用户初次登录,输入用户名密码

密码验证:服务器从数据库取出用户名和密码进行验证

生成JWT:服务器端验证通过,根据从数据库返回的信息,以及预设规则,生成JWT

返还JWT:服务器的HTTP RESPONSE中将JWT返还

带JWT的请求:以后客户端发起请求,HTTP REQUEST HEADER中的Authorizatio字段都要有值,为JWT

Install-Package JWT

实战教程

install-package Thinktecture.IdentityModel.Core
install-package Microsoft.Owin.Security.Jwt

 解决错误

http://home.bdqn.cn/thread-13632-1-1.html

在IIS中访问APS页面时提示:“最可能的原因使用的托管的处理程序,但是未安装或未完整安装asp.net“

打开CMD窗口,执行下面的命令:

"%WINDIR%\Microsoft.NET\Framework\v4.0.30319\aspnet_regiis.exe" -iru -enable

认证原理

一个不记名 token 包含了三部分:header,payload,signature。

header 是 token 的一部分,用来存放 token 的类型和编码方式,通常是使用 base-64 编码。

payload 包含了信息。你可以存放任一种信息,比如用户信息,产品信息等。它们都是使用 base-64 编码方式进行存储。

signature 包括了 header,payload 和密钥的混合体。

 

代码实战

JsonWebToken.Validate(accessToken, ApiAccount.AppSecret, (int)AppSettings.TokenTimeout.TotalSeconds);

 

参考资料

https://www.cnblogs.com/danvic712/p/10331976.html

http://www.ruanyifeng.com/blog/2018/07/json_web_token-tutorial.html

http://www.cnblogs.com/grissom007/p/6294746.html

http://www.cnblogs.com/selimsong/p/8184904.html

https://www.cnblogs.com/xz816111/p/9620139.html

posted @ 2017-01-18 16:27  ~沐风  阅读(5578)  评论(0编辑  收藏  举报