첨부 실행 코드는 나눔고딕코딩 폰트를 사용합니다.
유용한 소스 코드가 있으면 icodebroker@naver.com으로 보내주시면 감사합니다.
블로그 자료는 자유롭게 사용하세요.

728x90
반응형

■ ILogger 인터페이스 : BeginScope 메소드를 사용해 로그 범위 설정하기

------------------------------------------------------------------------------------------------------------------------


TestProject.zip


appsettings.json

 

 

{

    "Logging" :

    {

        "Debug" :

        {

            "LogLevel" :

            {

                "Default" : "Information"

            }

        },

        "Console" :

        {

            "IncludeScopes" : true,

            "LogLevel"      :

            {

                "Microsoft" : "Warning",

                "Default"   : "Information"

            }

        },

        "LogLevel" :

        {

            "Default" : "Debug"

        }

    },

    "AllowedHosts" : "*"

}

 

 

appsettings.Development.json

 

 

{

    "Logging" :

    {

        "Debug" :

        {

            "LogLevel" :

            {

                "Default" : "Information"

            }

        },

        "Console" :

        {

            "IncludeScopes" : true,

            "LogLevel"      :

            {

                "Microsoft" : "Warning",

                "Default"   : "Information"

            }

        },

        "LogLevel" :

        {

            "Default" : "Debug"

        }

    }

}

 

 

Controllers/TestController.cs

 

 

using Microsoft.AspNetCore.Mvc;

using Microsoft.Extensions.Logging;

 

namespace TestProject.Controllers

{

    /// <summary>

    /// 테스트 컨트롤러

    /// </summary>

    public class TestController : Controller

    {

        //////////////////////////////////////////////////////////////////////////////////////////////////// Field

        ////////////////////////////////////////////////////////////////////////////////////////// Private

 

        #region Field

 

        /// <summary>

        /// 로그 기록기

        /// </summary>

        private ILogger<TestController> logger;

 

        #endregion

 

        //////////////////////////////////////////////////////////////////////////////////////////////////// Constructor

        ////////////////////////////////////////////////////////////////////////////////////////// Public

 

        #region 생성자 - TestController(logger)

 

        /// <summary>

        /// 생성자

        /// </summary>

        /// <param name="logger">로그 기록기</param>

        public TestController(ILogger<TestController> logger)

        {

            this.logger = logger;

        }

 

        #endregion

 

        //////////////////////////////////////////////////////////////////////////////////////////////////// Method

        ////////////////////////////////////////////////////////////////////////////////////////// Public

 

        #region 인덱스 페이지 처리하기 - Index()

 

        /// <summary>

        /// 인덱스 페이지 처리하기

        /// </summary>

        /// <returns>액션 결과</returns>

        public IActionResult Index()

        {

            using(this.logger.BeginScope("PROCESS INDEX"))

            {

                this.logger.LogInformation(100, "BEGIN GET DATA");

 

                // 데이터를 처리한다.

 

                this.logger.LogInformation(200, "END GET DATA");

            }

 

            return View();

        }

 

        #endregion

    }

}

 

------------------------------------------------------------------------------------------------------------------------

728x90
반응형
Posted by 사용자 icodebroker

댓글을 달아 주세요