>  기사  >  백엔드 개발  >  asp.net 코어는 DI를 사용하여 맞춤형 사용자 시스템을 구현합니다.

asp.net 코어는 DI를 사용하여 맞춤형 사용자 시스템을 구현합니다.

大家讲道理
大家讲道理원래의
2017-05-28 11:41:331863검색

머리말

사실 asp.net 코어와 함께 제공되는 복잡한 사용자 시스템이 필요하지 않은 경우가 많으므로 역할과 다양한 개념을 기반으로 EF Core를 사용해야 하며 모든 정보는 EF Core에 저장됩니다. 웹 애플리케이션을 cookie에 저장합니다. (저는 쿠키에 넣는 것을 좋아하지 않습니다. 한 번은 Mac 시스템의 Safari 브라우저에서 웹 애플리케이션을 실행했을 때 크로스 도메인 쿠키를 설정할 수 없다는 문제를 겪었기 때문입니다. , 그래서 아주 특별한 방법을 사용해야 했습니다. , iframe이라는 것이 꽤 번거로워서 아직도 맞춤형 header)에 넣는 것을 좋아합니다. 마이크로소프트에게 납치당했습니다. 그러나 이것은 전적으로 개인적인 취향입니다. 원하는 대로 수행할 수 있습니다. 여기서는 한 가지 더 선택할 수 있도록 다른 방법을 제공합니다.

나는 asp.net 코어의 Dependency Insertion을 사용하여 내 시스템에 대한 사용자 인증 및 권한 부여 세트를 정의합니다. 나를 참조하여 자신만의 시스템을 정의할 수 있으며 이는 사용자 시스템에만 국한되지 않습니다.

관점 지향 프로그래밍(AOP)

제 생각에는 Mid

dleware와 Filter가 모두 asp.net 코어의 측면입니다. 이 두 곳에 인증과 승인을 둘 수 있습니다. 저는 개인적으로 불법 공격을 조기에 차단하고 대응할 수 있는 미들웨어에 인증을 넣는 것을 선호합니다.

종속성 주입(DI)

3가지 유형의 종속성 주입이 있습니다.

Life Cycle

1. 동일한 요청의 시작부터 끝까지. (services.AddScoped)

2. 주입될 때마다 새로 생성됩니다. (services.AddTransient)

3. 싱글톤, 애플리케이션 시작부터 애플리케이션 종료까지. (services.AddSingleton)

내 사용자 정의 사용자 클래스는 services.AddScoped를 사용합니다.

특정 방법

1. 사용자 클래스 정의


1     // 用户类,随便写的2     public class MyUser3     {4         public string Token { get; set; }5         public string UserName { get; set; }6     }
2. Startup.cs

에 사용자 클래스

ConfigureServices함수를 등록하세요.


1         // This method gets called by the runtime. Use this method to add services to the container.2         public void ConfigureServices(IServiceCollection services)3         {4             ...5             // 注册自定义用户类6             services.AddScoped(typeof(MyUser));7             ...8         }
services.AddScoped 방식으로 사용자 클래스를 등록하세요. 동일한 요청에서 미들웨어, 필터 및 컨트롤러

가 동일한 개체 를 참조 하기를 바랍니다.

3. 미들웨어에 주입


 1     // You may need to install the Microsoft.AspNetCore.Http.Abstractions package into your project 2     public class AuthenticationMiddleware 3     { 4         private readonly RequestDelegate _next; 5         private IOptions<HeaderConfig> _optionsAccessor; 6  7         public AuthenticationMiddleware(RequestDelegate next, IOptions<HeaderConfig> optionsAccessor) 8         { 9             _next = next;10             _optionsAccessor = optionsAccessor;11         }12 13         public async Task Invoke(HttpContext httpContext, MyUser user)14         {15             var token = httpContext.Request.Headers[_optionsAccessor.Value.AuthHeader].FirstOrDefault();16             if (!IsValidate(token))17             {18                 httpContext.Response.StatusCode = (int)HttpStatusCode.Forbidden;19                 httpContext.Response.ContentType = "text/plain";20                 await httpContext.Response.WriteAsync("UnAuthentication");21             }22             else23             {24                 // 设置用户的token25                 user.Token = token;26                 await _next(httpContext);27             }28         }29 30         // 随便写的,大家可以加入些加密,解密的来判断合法性,大家自由发挥31         private bool IsValidate(string token)32         {33             return !string.IsNullOrEmpty(token);34         }35     }36 37     // Extension method used to add the middleware to the HTTP request pipeline.38     public static class AuthenticationMiddlewareExtensions39     {40         public static IApplicationBuilder UseAuthenticationMiddleware(this IApplicationBuilder builder)41         {42             return builder.UseMiddleware<AuthenticationMiddleware>();43         }44     }
범위 지정 모드에서

인터페이스/클래스를 미들웨어에 주입하려면 클래스/인터페이스를 Invoke에 주입해야 한다는 것을 알았습니다. function parameters, 미들웨어가 기본 클래스나 인터페이스를 상속하지 않고 기본 클래스나 인터페이스에 있는 경우 Invoke를 정의하지 않는 이유이기도 합니다. 또는 인터페이스에서 Invoke를 정의하면 이 Invoke의 매개변수를 고정해야 하는 것이 불가피하며 종속성 주입이 쉽지 않습니다. 4. 특정 경로를 구성해야만 미들웨어가 사용됩니다.

 1         // This method gets called by the runtime. Use this method to configure the HTTP request pipeline. 2         public void Configure(IApplicationBuilder app, IHostingEnvironment env, ILoggerFactory loggerFactory) 3         { 4             loggerFactory.AddConsole(Configuration.GetSection("Logging")); 5             loggerFactory.AddDebug(); 6             // Set up nlog 7             loggerFactory.AddNLog(); 8             app.AddNLogWeb(); 9 10             // 除了特殊路径外,都需要加上认证的Middleware11             app.MapWhen(context => !context.Request.Path.StartsWithSegments("/api/token")12                                  && !context.Request.Path.StartsWithSegments("/swagger"), x =>13             {14                 // 使用自定义的Middleware15                 x.UseAuthenticationMiddleware();16                 // 使用通用的Middleware17                 ConfigCommonMiddleware(x);18             });19             // 使用通用的Middleware20             ConfigCommonMiddleware(app);21 22             // Enable middleware to serve generated Swagger as a JSON endpoint.23             app.UseSwagger();24 25             // Enable middleware to serve swagger-ui (HTML, JS, CSS etc.), specifying the Swagger JSON endpoint.26             app.UseSwaggerUI(c =>27             {28                 c.SwaggerEndpoint("/swagger/v1/swagger.json", "My API V1");29             });30         }31 32         // 配置通用的Middleware33         private void ConfigCommonMiddleware(IApplicationBuilder app)34         {35             // cors36             app.UseCors("AllowAll");37 38             app.UseExceptionMiddleware();39             // app.UseLogRequestMiddleware();40             app.UseMvc();41         }

토큰을 얻거나 API 문서를 보는 데는 인증이 필요하지 않습니다.

5. Inject into Filter

 1     public class NeedAuthAttribute : ActionFilterAttribute 2     { 3         private string _name = string.Empty; 4         private MyUser _user; 5  6         public NeedAuthAttribute(MyUser user, string name = "") 7         { 8             _name = name; 9             _user = user;10         }11 12         public override void OnActionExecuting(ActionExecutingContext context)13         {14             this._user.UserName = "aaa";15         }16     }

여기서
string

매개변수를 사용하여 클래스를 만들었습니다. 예를 들어 특정 인터페이스를 특정 사용자만 사용하도록 제한하는 등의 이유로 이 필터를 다시 사용할 수 있기 때문입니다. 문자열은 일종의 사용자 식별 정보를 저장할 수 있습니다.

Filter는 데이터베이스 액세스 클래스를 주입할 수도 있으므로 데이터베이스의 토큰을 통해 해당 사용자 정보를 얻을 수 있습니다.

6. 필터 사용

1 [TypeFilter(typeof(NeedAuthAttribute), Arguments = new object[]{ "bbb" }, Order = 1)]2 public class ValuesController : Controller

여기에서는 TypeFilter를 사용하여 종속성 주입을 사용하여 필터를 로드하고 매개변수와 필터 순서를 설정할 수 있습니다.

기본 필터 순서는 전역 설정->컨트롤러->작업이며 기본적으로 순서는 0입니다. 순서를 설정하여 이 순서를 변경할 수 있습니다.

7. 컨트롤러에 주입

 1     public class ValuesController : Controller 2     { 3         private MyUser _user; 4  5         public ValuesController(MyUser user) 6         { 7             _user = user; 8         } 9         ...10     }

컨트롤러의 생성자에 주입하면 컨트롤러의 작업에서 사용자 지정 사용자를 사용할 수 있고 현재 이 작업을 호출하는 사용자를 알 수 있습니다.

위 내용은 asp.net 코어는 DI를 사용하여 맞춤형 사용자 시스템을 구현합니다.의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.