LogoutRedirectController 구현하기

  • 2 minutes to read

이 문서는 클라이언트(JavaScript 등)에서 호출하여 사용자의 인증 세션을 종료하고 returnUrl 정보를 유지한 채 Login 페이지로 자동 이동시키는 LogoutRedirectController 구현 방법을 설명합니다.

이 기능은 세션 만료, 강제 로그아웃, 보안 정책 변경 시 자동 로그아웃 처리에 매우 유용합니다.


1. 컨트롤러 코드

아래 코드는 /LogoutRedirect 경로로 GET 요청이 오면 로그아웃을 수행한 뒤 /Identity/Account/Login 페이지로 리디렉션합니다. 이때 Uri.EscapeDataString 을 사용하여 returnUrl 값에 포함된 특수문자(?, &, = 등)가 URL에서 깨지지 않도록 안전한 URL 인코딩을 적용합니다.

using Microsoft.AspNetCore.Identity;
using Microsoft.AspNetCore.Mvc;
using System;
using System.Threading.Tasks;

namespace Azunt.Web.Controllers
{
    // JS 등에서 호출할 때 CSRF 검사를 건너뛰기 위해 사용
    [IgnoreAntiforgeryToken]
    public class LogoutRedirectController : Controller
    {
        private readonly SignInManager<ApplicationUser> _signInManager;

        // DI로 SignInManager 받아오기
        public LogoutRedirectController(SignInManager<ApplicationUser> signInManager)
        {
            _signInManager = signInManager;
        }

        // /LogoutRedirect 경로로 GET 요청 처리
        [HttpGet("/LogoutRedirect")]
        public async Task<IActionResult> Index(string returnUrl = "/")
        {
            // 로그인 상태라면 로그아웃 실행
            if (_signInManager.IsSignedIn(User))
            {
                await _signInManager.SignOutAsync();
            }

            // 로그인 페이지로 이동하면서 returnUrl 전달
            // Uri.EscapeDataString: 특수문자 인코딩을 통해 안전한 URL 생성
            var loginUrl = $"/Identity/Account/Login?returnUrl={Uri.EscapeDataString(returnUrl)}";

            // 로그인 페이지로 리디렉션
            return Redirect(loginUrl);
        }
    }
}

2. 동작 방식

  1. /LogoutRedirect 엔드포인트 호출
  2. 서버에서 로그인 여부 확인 후 로그아웃 처리
  3. Login 페이지로 리디렉션
  4. 로그인 성공 시 returnUrl 로 복귀

예시 요청:

/LogoutRedirect?returnUrl=/Dashboard

→ 로그아웃 후 /Identity/Account/Login?returnUrl=/Dashboard 로 자동 이동합니다.


3. JavaScript에서 사용 예

window.location.href = "/LogoutRedirect?returnUrl=" 
    + encodeURIComponent(location.pathname + location.search);

브라우저 URL의 현재 경로와 쿼리스트링을 안전하게 인코딩하여 전달합니다.


4. 사용 목적

  • 세션 만료 감지 후 자동 로그아웃 처리
  • 보안 정책 변경 시 강제 재로그인 유도
  • 여러 테넌트/포털 환경에서 공통 로그아웃 처리
  • returnUrl 기반의 자연스러운 재인증 UX 제공
더 깊이 공부하고 싶다면
DevLec에서는 실무 중심의 C#, .NET, ASP.NET Core, Blazor, 데이터 액세스 강좌를 단계별로 제공합니다. 현재 수강 가능한 강좌 외에도 더 많은 과정이 준비되어 있습니다.
DevLec.com에서 자세한 커리큘럼을 확인해 보세요.
DevLec 공식 강의
C# Programming
C# 프로그래밍 입문
프로그래밍을 처음 시작하는 입문자를 위한 C# 기본기 완성 과정입니다.
ASP.NET Core 10.0
ASP.NET Core 10.0 시작하기 MVC Fundamentals Part 1 MVC Fundamentals Part 2
웹 애플리케이션의 구조와 MVC 패턴을 ASP.NET Core로 실습하며 익힐 수 있습니다.
Blazor Server
풀스택 웹개발자 과정 Part 1 풀스택 웹개발자 과정 Part 2 풀스택 웹개발자 과정 Part 3
실무에서 바로 활용 가능한 Blazor Server 기반 관리자·포털 프로젝트를 만들어 봅니다.
Data & APIs
Entity Framework Core 시작하기 ADO.NET Fundamentals Blazor Server Fundamentals Minimal APIs
데이터 액세스와 Web API를 함께 이해하면 실무 .NET 백엔드 개발에 큰 도움이 됩니다.
VisualAcademy Docs의 모든 콘텐츠, 이미지, 동영상의 저작권은 박용준에게 있습니다. 저작권법에 의해 보호를 받는 저작물이므로 무단 전재와 복제를 금합니다. 사이트의 콘텐츠를 복제하여 블로그, 웹사이트 등에 게시할 수 없습니다. 단, 링크와 SNS 공유, Youtube 동영상 공유는 허용합니다. www.VisualAcademy.com
박용준 강사의 모든 동영상 강의는 데브렉에서 독점으로 제공됩니다. www.devlec.com