appsettings.json 파일

  • 2 minutes to read

appsettings.json과 secrets.json 설명

1. appsettings.json

  • 역할: 애플리케이션의 환경 설정을 저장하는 파일
  • 위치: 프로젝트 루트 디렉터리
  • 주요 내용: 데이터베이스 연결 문자열, 로깅 설정, 기타 애플리케이션 구성값
예제 (기본 형식)
{
    "ConnectionStrings": {
        "DefaultConnection": "Server=(localdb)\\mssqllocaldb;Database=Hawaso;Trusted_Connection=True;MultipleActiveResultSets=true"
    },
    "Logging": {
        "LogLevel": {
            "Default": "Information",
            "Microsoft.AspNetCore": "Warning"
        }
    },
    "AllowedHosts": "*"
}
  • ConnectionStrings: 데이터베이스 연결 문자열을 저장
  • Logging: 로깅 수준을 설정
  • AllowedHosts: 허용된 호스트를 지정

2. secrets.json

  • 역할: 민감한 정보(비밀번호, API 키 등)를 저장하는 보안 파일
  • 위치: 사용자 프로필 디렉터리 (appsettings.json과 다른 경로)
  • Git에 포함되지 않음: 소스 코드 저장소에서 제외되어 보안이 유지됨
  • 환경별 파일 없음: appsettings.Development.json 같은 환경별 설정이 없고, 한 개의 파일로 관리됨
예제
{
    "ConnectionStrings": {
        "DefaultConnection": "Server=localhost;Database=Hawaso;User Id=sa;Password=SuperSecretPassword;"
    },
    "ApiKeys": {
        "GoogleMaps": "YOUR_SECRET_GOOGLE_MAPS_API_KEY"
    }
}
  • secrets.json은 Git에서 제외되므로 appsettings.json보다 보안성이 높음
  • API 키, 비밀번호 같은 데이터는 appsettings.json이 아닌 secrets.json에 저장하는 것이 좋음

3. Blazor Server에서 secrets.json 사용 방법

1) 비밀 저장소 활성화
dotnet user-secrets init
2) 비밀 추가
dotnet user-secrets set "ConnectionStrings:DefaultConnection" "Server=localhost;Database=Hawaso;User Id=sa;Password=SuperSecretPassword;"
3) Blazor Server에서 불러오기
using Microsoft.Extensions.Configuration;

var builder = WebApplication.CreateBuilder(args);
builder.Configuration.AddUserSecrets<Program>(); // secrets.json 추가

var connectionString = builder.Configuration.GetConnectionString("DefaultConnection");
Console.WriteLine($"DB 연결 문자열: {connectionString}");

4. 차이점 정리

특징 appsettings.json secrets.json
목적 일반적인 애플리케이션 설정 민감한 정보 저장
저장 위치 프로젝트 폴더 사용자 프로필 디렉터리
Git 포함 여부 포함됨 포함되지 않음
환경별 지원 가능 (appsettings.Development.json 등) 없음

5. 정리

  • appsettings.json은 애플리케이션의 일반적인 설정을 저장하는 파일
  • secrets.json은 보안이 필요한 데이터를 저장하며, Git에 포함되지 않음
  • Configuration을 통해 두 파일의 데이터를 쉽게 불러와 사용할 수 있음
  • API 키나 비밀번호 같은 정보는 secrets.json을 사용하여 보안 유지
더 깊이 공부하고 싶다면
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