MiniAuth - 轻量级.Net开源身份认证中间件

文章目录

.NetCore身份认证组件MiniAuth

安装MiniAuth组件

install-package MiniAuth

在Startup/Program配置和启用MiniAuth

csharp 复制代码
            var builder = WebApplication.CreateBuilder(args);

            //注入MiniAuth(越早注入越好)
            builder.Services.AddMiniAuth(miniAuthOption =>
            {
                //修改认证类型
                miniAuthOption.AuthenticationType = AuthType.BearerJwt;
                //修改秘钥
                miniAuthOption.JWTKey = new SymmetricSecurityKey(Encoding.UTF8.GetBytes("cvzRqFw9m7HPNePy"));
                //修改MiniAuth数据库链接
                miniAuthOption.SqliteConnectionString = "Source=lingbug_miniauth_identity.db";
            });

            builder.Services.AddControllers();
            builder.Services.AddEndpointsApiExplorer();
            builder.Services.AddSwaggerGen();

            var app = builder.Build();

            if (app.Environment.IsDevelopment())
            {
                app.UseSwagger();
                app.UseSwaggerUI();
            }

            app.UseHttpsRedirection();
            app.UseAuthorization();
            app.MapControllers();

            app.Run();

MiniAuth默认配置

csharp 复制代码
    internal class MiniAuthOption
    {
        public static string RoutePrefix = "MiniAuth";
        public static string LoginPath = $"/{RoutePrefix}/login.html";
        public static bool DisableMiniAuthLogin = false;

        public static AuthType AuthenticationType = AuthType.Cookie;
        public static SecurityKey JWTKey = new SymmetricSecurityKey(Encoding.UTF8.GetBytes("this is miniauth key for demo"));
        /// <summary>
        /// Token expires in seconds, default is 1 hour
        /// </summary>
        public static int TokenExpiresIn = 60 * 60;
        public static string Issuer = $"{RoutePrefix}";
        public static string SqliteConnectionString = "Data Source=miniauth_identity.db";
    }

MiniAuth认证类型枚举

csharp 复制代码
    public enum AuthType
    {
        Cookie,
        BearerJwt
    }

配置完成,启动项目,访问管理界面

  • 地址:http://localhost:5025/MiniAuth/index.html
  • 注意:首次访问会提示未授权,登录后即可正常访问
  • 登录管理界面账号密码:
  • 账号:admin@mini-software.github.io
  • 密码:E7c4f679-f379-42bf-b547-684d456bc37f(请及时修改密码)

管理界面的端口(Endpoints 管理)

名称 路由
HTTP: POST /MiniAuth/refreshToken /MiniAuth/refreshToken
HTTP: POST /MiniAuth/login /MiniAuth/login
HTTP: POST /MiniAuth/api/saveUser /MiniAuth/api/saveUser
HTTP: POST /MiniAuth/api/saveRole /MiniAuth/api/saveRole
HTTP: POST /MiniAuth/api/resetPassword /MiniAuth/api/resetPassword
HTTP: POST /MiniAuth/api/getUsers /MiniAuth/api/getUsers
HTTP: POST /MiniAuth/api/getConfig /MiniAuth/api/getConfig
HTTP: POST /MiniAuth/api/deleteUser /MiniAuth/api/deleteUser
HTTP: POST /MiniAuth/api/deleteRole /MiniAuth/api/deleteRole
HTTP: GET /MiniAuth/logout /MiniAuth/logout
HTTP: GET /MiniAuth/api/getUserInfo /MiniAuth/api/getUserInfo
HTTP: GET /MiniAuth/api/getRoles /MiniAuth/api/getRoles
HTTP: GET /MiniAuth/api/getAllEndpoints /MiniAuth/api/getAllEndpoints
HTTP: GET /MiniAuth/AccessDenied /MiniAuth/AccessDenied
相关推荐
该用户已不存在3 小时前
6个值得收藏的.NET ORM 框架
前端·后端·.net
小码编匠7 小时前
WPF 中的高级交互通过右键拖动实现图像灵活缩放
后端·c#·.net
追逐时光者8 小时前
一个基于 .NET 开源、简易、轻量级的进销存管理系统
后端·.net
唐青枫14 小时前
C#.NET 定时任务与队列利器:Hangfire 完整教程
c#·.net
hez201020 小时前
Runtime Async - 步入高性能异步时代
c#·.net·.net core·clr
追逐时光者1 天前
.NET Fiddle:一个方便易用的在线.NET代码编辑工具
后端·.net
mudtools1 天前
.NET驾驭Word之力:玩转文本与格式
c#·.net
唐青枫2 天前
C#.NET 数据库开发提速秘籍:SqlSugar 实战详解
c#·.net
追逐时光者2 天前
精选 4 款基于 .NET 开源、功能强大的 Windows 系统优化工具
后端·.net
mudtools2 天前
.NET驾驭Word之力:理解Word对象模型核心 (Application, Document, Range)
c#·.net