오픈 소스 DDD 디자인 모델 프레임 워 크 YMNNetCoreFrameWork 제3 편 - ASP. net core Identity 인증 추가, JWT 인증 추가

8408 단어
1. 프레임 워 크 에 Identity 등록 기능 추가
2. 프레임 워 크 에 idenity 를 추가 하여 로그 인 후 JWTtoken 가 져 오기
3. 요청 인 터 페 이 스 는 token 요청 을 통 해 인증 기능 을 증가 합 니 다.
소스 코드 주소:https://github.com/topgunymn/YMNNetCoreFrameWork
 
JWTtoken 생 성 코드:
 private string CreateAccessToken(IEnumerable claims, TimeSpan? expiration = null)
        {
            var now = DateTime.UtcNow;
            SymmetricSecurityKey symmetricSecurityKey =   new SymmetricSecurityKey(Encoding.ASCII.GetBytes(_configuration.GetSection("Authentication:JwtBearer")["SecurityKey"].ToString()));
            var jwtSecurityToken = new JwtSecurityToken(
                issuer: _configuration.GetSection("Authentication:JwtBearer")["Issuer"].ToString(),
                audience: _configuration.GetSection("Authentication:JwtBearer")["Audience"].ToString(),
                claims: claims,
                notBefore: now,
                expires:now.AddMinutes(30),
                // expires: now.Add(expiration ?? _configuration.Expiration),  SecurityKey
                signingCredentials: new SigningCredentials(symmetricSecurityKey, SecurityAlgorithms.HmacSha256)
            );

            return new JwtSecurityTokenHandler().WriteToken(jwtSecurityToken);
        }

 
JWT 인증 설정 코드:
services.AddIdentity()
  .AddEntityFrameworkStores() ;
            //services.AddAuthentication(JwtBearerDefaults.AuthenticationScheme)
            // //  jwt  :
            // .AddJwtBearer(JwtBearerDefaults.AuthenticationScheme, options =>
            // {
            services.AddAuthentication(options =>
            {
                     //identity.application
                     var a = options.DefaultAuthenticateScheme;
                var b = options.DefaultChallengeScheme;
                options.DefaultAuthenticateScheme = "JwtBearer";
                options.DefaultChallengeScheme = "JwtBearer";
            }).AddJwtBearer("JwtBearer", options =>
            {
                options.TokenValidationParameters = new TokenValidationParameters
                {
                    ValidateLifetime = true,//        
                    ClockSkew = TimeSpan.FromSeconds(30),

                    ValidateAudience = true,//    Audience
                                            //ValidAudience = Const.GetValidudience(),//Audience
                                            //           ,      ,  token, token      
                    AudienceValidator = (m, n, z) =>
                  {
                      return m != null && m.FirstOrDefault().Equals(Audience);
                  },
                    ValidateIssuer = true,//    Issuer
                    ValidIssuer = Issuer,//Issuer,        jwt     

                    ValidateIssuerSigningKey = true,//    SecurityKey
                    IssuerSigningKey = new SymmetricSecurityKey(Encoding.UTF8.GetBytes(key))//  SecurityKey
                };
                //options.Events = new JwtBearerEvents
                //{
                //    OnAuthenticationFailed = context =>
                //    {
                //        //Token expired
                //        if (context.Exception.GetType() == typeof(SecurityTokenExpiredException))
                //        {
                //            context.Response.Headers.Add("Token-Expired", "true");
                //        }
                //        return Task.CompletedTask;
                //    }
                //};
            });

좋은 웹페이지 즐겨찾기