BookStore Spring - .env file setup / .env configuration with application.yml

Foreword

After I created Spring Boot Project, and linked it to remote repositories.

For DB connection and other configuration (will add JWT, cookie, Email and etc), I want to enclose private information.

Using .env file can be useful for it.

( .env + application.yml pair )

Consequently,

.env -> private info, add it to .gitignore

application.yml -> add place holder that alines with .env file -> will be updated to gitHub

1.Add dependencies for reading .env file

Add dependencies

plugins {
    id 'java'
    id 'org.springframework.boot' version '3.3.2'
    id 'io.spring.dependency-management' version '1.1.6'
}

group = 'com.example'
version = '0.0.1-SNAPSHOT'

java {
    toolchain {
       languageVersion = JavaLanguageVersion.of(17)
    }
}

configurations {
    compileOnly {
       extendsFrom annotationProcessor
    }
}

repositories {
    mavenCentral()
}

dependencies {
    implementation 'org.springframework.boot:spring-boot-starter-data-jpa'
    implementation 'org.springframework.boot:spring-boot-starter-security'
    implementation 'org.springframework.boot:spring-boot-starter-web'
    compileOnly 'org.projectlombok:lombok'
    runtimeOnly 'com.mysql:mysql-connector-j'
    annotationProcessor 'org.projectlombok:lombok'
    testImplementation 'org.springframework.boot:spring-boot-starter-test'
    testImplementation 'org.springframework.security:spring-security-test'
    testRuntimeOnly 'org.junit.platform:junit-platform-launcher'

    //For reading .env file (Both dependencies below work)
    implementation 'io.github.cdimascio:java-dotenv:+'
    //implementation 'io.github.cdimascio:java-dotenv:5.2.2'
}

tasks.named('test') {
    useJUnitPlatform()
}

2.Create .env file

: hover on BookStore directory, and then create File .env

3.Add configuration in .env

BookStore (dir) -> .env


DB_URL=jdbc:mysql://localhost:3306/BookStore
DB_USERNAME=root
DB_PASSWORD=password1234

4.Add placeholders for .env file to application.yml

src -> resources -> application.yml

spring:
  datasource:
    url: ${DB_URL}
    username: ${DB_USERNAME}
    password: ${DB_PASSWORD}
    driver-class-name: com.mysql.cj.jdbc.Driver
  jpa:
    database-platform: org.hibernate.dialect.MySQLDialect
    hibernate:
      ddl-auto: create
      show-sql: true

5.Add .env to .gitignore

6.Run applicationon

runs well!

Consequently

.env -> private info, add it to .gitignore

application.yml -> add place holder that alines with .env file -> will be updated to gitHub


Error from misconfiguration

:: this is for logging, documentation above works well. you can follow its reference.

1.application.yml misconfiguration

src -> resources -> application.yml

spring:
  datasource:
    url: ${DB_URL}
    username: ${DB_USERNAME}
    password: ${DB_PASSWORD}
  jpa:
    hibernate:
      ddl-auto: create

\==> Error (URL must start with 'jdbc')

Resolve


2.build.gradle for .env - wrong dependency

Both dependencies above work.