- Login.razor: BCrypt 기반 실제 비밀번호 검증 - TaxBaik.Admin.csproj: BCrypt.Net-Next 패키지 추가 - HttpContext.SignInAsync로 쿠키 인증 처리 주의: 아직 런타임 이슈 수정 필요 Co-Authored-By: Claude Haiku 4.5 <noreply@anthropic.com>
This commit is contained in:
@@ -29,16 +29,65 @@
|
|||||||
</MudPaper>
|
</MudPaper>
|
||||||
</MudContainer>
|
</MudContainer>
|
||||||
|
|
||||||
|
@using Microsoft.AspNetCore.Authentication
|
||||||
|
@using System.Security.Claims
|
||||||
|
@using TaxBaik.Domain.Interfaces
|
||||||
|
|
||||||
@code {
|
@code {
|
||||||
private MudForm form;
|
private MudForm form;
|
||||||
private bool isFormValid = false;
|
private bool isFormValid = false;
|
||||||
private string errorMessage = "";
|
private string errorMessage = "";
|
||||||
|
|
||||||
private LoginModel model = new();
|
private LoginModel model = new();
|
||||||
|
private bool isLoading = false;
|
||||||
|
|
||||||
|
[Inject]
|
||||||
|
private IAdminUserRepository AdminUserRepository { get; set; }
|
||||||
|
|
||||||
|
[Inject]
|
||||||
|
private NavigationManager NavigationManager { get; set; }
|
||||||
|
|
||||||
|
[Inject]
|
||||||
|
private HttpContextAccessor HttpContextAccessor { get; set; }
|
||||||
|
|
||||||
private async Task HandleLogin()
|
private async Task HandleLogin()
|
||||||
{
|
{
|
||||||
errorMessage = "로그인 기능은 준비 중입니다.";
|
if (!isFormValid) return;
|
||||||
|
isLoading = true;
|
||||||
|
errorMessage = "";
|
||||||
|
|
||||||
|
try
|
||||||
|
{
|
||||||
|
var user = await AdminUserRepository.GetByUsernameAsync(model.Username);
|
||||||
|
if (user == null || !BCrypt.Net.BCrypt.Verify(model.Password, user.PasswordHash))
|
||||||
|
{
|
||||||
|
errorMessage = "사용자명 또는 비밀번호가 올바르지 않습니다.";
|
||||||
|
isLoading = false;
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
var claims = new List<Claim>
|
||||||
|
{
|
||||||
|
new Claim(ClaimTypes.NameIdentifier, user.Id.ToString()),
|
||||||
|
new Claim(ClaimTypes.Name, user.Username)
|
||||||
|
};
|
||||||
|
var claimsIdentity = new ClaimsIdentity(claims, CookieAuthenticationDefaults.AuthenticationScheme);
|
||||||
|
var authProperties = new AuthenticationProperties { IsPersistent = true };
|
||||||
|
|
||||||
|
await HttpContextAccessor.HttpContext.SignInAsync(
|
||||||
|
CookieAuthenticationDefaults.AuthenticationScheme,
|
||||||
|
new ClaimsPrincipal(claimsIdentity),
|
||||||
|
authProperties);
|
||||||
|
|
||||||
|
NavigationManager.NavigateTo("/taxbaik/admin/dashboard");
|
||||||
|
}
|
||||||
|
catch (Exception ex)
|
||||||
|
{
|
||||||
|
errorMessage = $"로그인 중 오류: {ex.Message}";
|
||||||
|
}
|
||||||
|
finally
|
||||||
|
{
|
||||||
|
isLoading = false;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private class LoginModel
|
private class LoginModel
|
||||||
|
|||||||
@@ -13,6 +13,7 @@
|
|||||||
|
|
||||||
<ItemGroup>
|
<ItemGroup>
|
||||||
<PackageReference Include="MudBlazor" Version="6.9.4" />
|
<PackageReference Include="MudBlazor" Version="6.9.4" />
|
||||||
|
<PackageReference Include="BCrypt.Net-Next" Version="4.0.3" />
|
||||||
</ItemGroup>
|
</ItemGroup>
|
||||||
|
|
||||||
</Project>
|
</Project>
|
||||||
|
|||||||
Reference in New Issue
Block a user