ASP.NET Core는 기본적으로 종속성 주입 패턴을 사용하고 있어서 따로 설정할게 없지만 WPF는 그렇지 않습니다. 만약 종속성주입이 귀찮다 하면 종속성 없이 사용해도 됩니다. 연관글 영역 1. 프로젝트 준비 WPF 프로젝트를 생성하고 종속성 주입 구현을 위해서 아래 패키지를 누겟(Nuget)에서 찾아 설치해 줍니다. Microsoft.Extensions.DependencyInjection 이 프로젝트에서는 콘솔출력도 사용할 예정이라 아래 패키지도 설치해 줍니다. Microsoft.Extensions.Hosting 로그파일 출력은 아래 패키지를 이용합니다. NReco.Logging.File 2. 종속성 주입 구현 'App.xaml'에서 'StartupUri'를 제거해 줍니다. 'App.xaml.cs'..
윈폼(WinForm)은 종속성 구현이 안 돼 있으므로 굳이 일부로 구현해 가며 로거를 쓰는 것은 너무 번거롭습니다. 그래서 이 포스팅은 종속성 없이 사용하는 방법을 다룹니다. 자세한 설정방법은 이전 포스팅을 확인해 주세요 연관글 영역 0. 라이브러리 설치 이 플랫폼에는 기본 로거가 설치되어있지 않으므로 누겟에서 찾아서 설치해 줍니다. Microsoft.Extensions.Hosting 1. 로거팩토리(LoggerFactory) 생성 간단하게 로거팩토리(LoggerFactory)를 생성하여 사용하는 것이 좋습니다. 전역에서 접근할 수 있도록 스태틱(static)으로 선언한 로거팩토리(LoggerFactory)변수를 만들어 줍니다. /// /// 로거 팩토리 /// public static ILoggerFa..
클래스 라이브러리를 만들어 'Microsoft.AspNetCore.Mvc'에 있는 'ControllerBase'를 사용하려면 누겟(NuGet)에서 'Microsoft.AspNetCore.Mvc'를 받으면 됩니다. 그래서 누겟을 봤더니..... 1. 'Microsoft.AspNetCore.Mvc'는 빠졌다! 하도 옛날에 만들어 놓고 복붙만 해서 쓰던 프로젝트라 '사용되지 않음'상태가 되어 있었는지 이제 알았네요. 2. 'Microsoft.AspNetCore.Mvc'는 어디 갔는가? 정확하게는 누겟에서만 빠지는 거고 SDK에는 들어 있기 때문에 쓰는 데 지장은 없습니다. 2-1. 프로젝트의 기준 SDK를 변경하여 해결하는 방법 프로젝트가 자체를 ASP.NET Core로 바꿔도 되는 경우라면 프로젝트 파일(*..
테스트를 편하게 하려고 'ASP.NET Core'프로젝트에 프론트엔드(Front-end)를 넣어놨더니 개시하면 프론트엔드도 같이 빌드됩니다. 그래서 개시할 때마다 시간이 너무 오래 걸립니다.... 프론트엔드는 따로 관리하는 것이 편하므로 빌드도 따로 하여 배포하는 게 편한데 이러면 너무 불편하죠. 연관글 영역 해결 방법 의외로 해결 방법은 복사/붙여넣기 했던 코드에 나와있는데..... 프로젝트를 더블클릭하고 'Target Name="PublishRunWebpack"'로 되어 있는 부분을 찾습니다. 이 부분이 퍼블리싱이 끝나면 동작하는 내용입니다. 이 부분을 주석 처리하면 프론트엔드는 퍼블리싱하지 않습니다. 다시 게시하기 주석처리가 됐으면 다시 게시해 봅시다. 이제 게시를 해도 프론트엔드는 빌드되지 않습니..
1. 에러의 발견 포스트그레스 사용 시 다음과 같은 에러가 나는 경우가 있습니다. System.InvalidCastException: ''timestamp with time zone' literal cannot be generated for Local DateTime: a UTC DateTime is required' 포스트그레스 프로바인더가 6.x 버전부터 시간대가 포함된 타임스템프(timestamp with timezone)로 매핑해야 한다고 합니다. 2. ' DbContext'에서 설정하기 간편하게 해결하는 방법은 'DbContext'를 생성할 때 레거시 모드를 설정해 주는 것입니다. public ModelsDbContext_Postgresql(DbContextOptions options) : ba..
전 포스팅에서 .NET기본 로거를 사용하는 방법을 알아봤습니다. 로거를 파일로 출력하려면 외부 라이브러리를 사용해야 합니다. 이 포스팅에서는 'NReco.Logging.File'를 이용하여 로그를 파일로 출력합니다. 연관글 영역 1. 라이브러리 설치 .NET에서 로그를 파일로 내보내는 기능은 외부 라이브러리를 쓰라고 되어 있습니다. (더 이상 기본기능으로 제공하지 않음) 이 포스팅에서는 'NReco.Logging.File'를 사용합니다. 2. 파일 출력 설정 파일 출력을 위해 파일명을 지정하고 로거빌더(LoggingBuilder)에서 출력 형식을 지정해 줍니다. 2-1. 'StartUp.cs'를 사용하지 않는 경우 서비스에서 'AddLogging'을 이용하여 외부 빌더를 설정해 줍니다. builder.S..
.NET 기본 로거가 종속성 주입이 귀찮아서 안 쓰고 있었는데... 장기적으로 봤을 때 'log4net'이 더 관리하기 힘는 거 같아서 이번 기회에 바꿔봤습니다 ㅎㅎㅎ 'ASP.NET Core'는 종속성 구성이 되어 있으므로 이 포스팅은 간단한 구현을 위해 'ASP.NET Core'를 이용합니다. 다른 플랫폼별로 따로 포스팅할 예정입니다. 연관글 영역 1. 로거(logger) 사용하기 종속성에 로거가 포함되어 있으므로 컨트롤러에서 로거를 전달받아 사용하면 됩니다. [Route("api/[controller]/[action]")] [ApiController] public class TestController : ControllerBase { /// /// 사용할 로거 /// private ILogger _..
.NET에서 'out'이나 'ref' 한정자를 쓰는데 다음과 같은 에러가 났습니다. A property or indexer may not be passed as an out or ref parameter 참조를 반환하지 않는 속성 또는 인덱서는 out 또는 ref 값으로 사용할 수 없음 1. 원인 MS가 제공하는 오류코드만 보고도 확인할 수 있는 오류입니다. 참고 : MS Learn - 컴파일러 오류 CS0206 겟터/셋터(getter/setter) 접근자를 이용하여 속성을 만들고 이것을 'out'이나 'ref' 한정자로 전달하려고 하면 발생하는 오류입니다. 아직도 종종 하는 실수인데..... .NET은 겟터/셋터(getter/setter) 접근자를 편하게 처리하기 위해 변수명을 그대로 사용할 수 있게 ..
모델에 FK(foreign key)를 연결하려고 상호 참조를 했더니 다음과 같은 에러가 납니다. Exception: Newtonsoft.Json.JsonSerializationException: Self referencing loop detected for property '[모델명]' with type '[네임스페이스]'. Path '[에러나 개체]'. at Newtonsoft.Json.Serialization.JsonSerializerInternalWriter.CheckForCircularReference(JsonWriter writer, Object value, JsonProperty property, JsonContract contract, JsonContainerContract container..
EF(Entity Framework, 엔트리 프레임워크)에서 데이터의 무결성을 확보하기 위해 '낙관적 동시성(Optimistic Concurrency)'을 어떻게 구현하는지 알아봅시다. 0. 낙관적 동시성을 쓰는 이유 낙관적 동시성을 쓰는 이유를 알려면 알아두어야 할 내용이 있습니다. 0-1. 비관적 동시성 DB에서 데이터의 일관성유지를 위해 락(lock)을 거는 방법이 있습니다. 이렇게 락을 거는 방법을 '비관적 동시성(Pessimisitc Concurrency)'이라고 합니다. 이 방법은 누군가 데이터를 수정하는 동안 다른 사람은 수정할 수 없게 만드는 방법입니다. 다른 사람이 수정할 수 없으니 절대적인 데이터 무결성이 보장된다는 장점이 있습니다. 하지만 동시에 여러 사람이 수정하려는 경우 나머지 사..