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
相关推荐
百锦再11 小时前
详细解析 .NET 依赖注入的三种生命周期模式
java·开发语言·.net·di·注入·模式·依赖
Kookoos15 小时前
ABP VNext + .NET Minimal API:极简微服务快速开发
后端·微服务·架构·.net·abp vnext
深盾科技15 小时前
.NET 安全之 JIT 保护技术深度解析
安全·.net
深盾科技17 小时前
深入解析 .NET 泛型:从原理到实战优化
windows·.net
唐青枫1 天前
C#.NET serilog 详解
c#·.net
步、步、为营2 天前
.net微服务框架dapr保存和获取状态
微服务·架构·.net
小码编匠2 天前
WPF 自定义TextBox带水印控件,可设置圆角
后端·c#·.net
SEO-狼术3 天前
Highcharts Dashboards provides crack
.net