ASP.NET Core 实现基本认证的示例代码
http基本认证
在http中,http基本认证(basic authentication)是一种允许网页浏览器或其他客户端程序以(用户名:口令) 请求资源的身份验证方式,不要求cookie,session identifier、login page等标记或载体。
- 所有浏览器据支持http基本认证方式
- 基本身证原理不保证传输凭证的安全性,仅被based64编码,并没有encrypted或者hashed,一般部署在客户端和服务端互信的网络,在公网中应用ba认证通常与https结合
https://en.wikipedia.org/wiki/basic_access_authentication
ba标准协议
ba认证协议的实施主要依靠约定的请求头/响应头,典型的浏览器和服务器的ba认证流程:
① 浏览器请求应用了ba协议的网站,服务端响应一个401认证失败响应码,并写入www-authenticate响应头,指示服务端支持ba协议
http/1.1 401 unauthorized
www-authenticate: basic realm="our site" # www-authenticate响应头包含一个realm域属性,指明http基本认证的是这个资源集
或客户端在第一次请求时发送正确authorization标头,从而避免被质询
② 客户端based64(用户名:口令),作为authorization标头值 重新发送请求。
authorization: basic userid:password
所以在http基本认证中认证范围与 realm有关(具体由服务端定义)
> 一般浏览器客户端对于www-authenticate质询结果,会弹出口令输入窗.
ba编程实践
aspnetcore网站利用fileservermiddleware 将路径映射到某文件资源, 现对该 文件资源访问路径应用 http ba协议。
asp.net core服务端实现ba认证:
① 实现服务端基本认证的认证过程、质询逻辑
②实现基本身份认证交互中间件basicauthenticationmiddleware ,要求对httpcontext使用 ba.scheme
③asp.net core 添加认证计划 , 为文件资源访问路径启用 ba中间件,注意使用usewhen插入中间件
startup.cs 文件添加并启用http基本认证
以上ba认证的服务端已经完成,现在可以在浏览器测试:
进一步思考?
浏览器在ba协议中行为: 编程实现ba客户端,要的同学可以直接拿去
that's all . ba认证是随处可见的基础认证协议,本文期待以最清晰的方式帮助你理解协议:
实现了基本认证协议服务端,客户端;
到此这篇关于asp.net core 实现基本认证的示例代码的文章就介绍到这了,更多相关asp.net core基本认证内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!
上一篇: 通过PHP实现用户注册后邮箱验证激活
下一篇: 如何从字典中随机选择一个键
推荐阅读
-
asp.net core MVC之实现基于token的认证
-
ASP.NET Core中实现用户登录验证的最低配置示例代码
-
ASP.NET Core 使用Cookie验证身份的示例代码
-
ASP.NET Core使用SkiaSharp实现验证码的示例代码
-
ASP.NET Core3.1 Ocelot认证的实现
-
ASP.NET MVC5 实现分页查询的示例代码
-
selenium+python实现基本自动化测试的示例代码
-
Springboot+Spring Security实现前后端分离登录认证及权限控制的示例代码
-
ASP.NET Core 2.0 支付宝扫码支付的实现代码
-
ASP.NET实现Hadoop增删改查的示例代码