728x90
아래와 같은 패키지 구조를 권장한다.
com
+- example
+- myproject
+- Application.java
|
+- domain
| +- Customer.java
| +- CustomerRepository.java
|
+- service
| +- CustomerService.java
|
+- web
| +- CustomerController.java
|
root package
:com.example.myproject
,모든 class와 기타 package는 모두 root package 하위에 위치.
- application main class:
Application.java
,해당 class는root packag 하위에 위치,일반적으로 해당 class에서 componet scan 설정을 한다.
root package 하위에 위치함으로서 수동설정을 줄이면서Spring 필요한것들도 정상적으로 loading 되게 할수 있다.
com.example.myproject.domain package
:엔티티 매핑 관계 정의 및 데이터 액세스 관련 인터페이스 및 구현
com.example.myproject.servicepackage
:비즈니스 로직 작성에 사용되는 인터페이스 및 구현
com.example.myproject.web
:Spring MVC의 Controller 등웹 계층 관련 구현을 작성하는 데 사용됩니다.
여기서 주의 해야 될 부분은 모든 root package 와
application main class 위치다.
application main class 가 root package 의 하위에 위치하였기때문에 하위 class 들도 마찬가지로 root package 의 하위에 위치 하도록 설정해야 되며 default 설정에서는 springboot가 알아서 root package 및 하위 class들을 초기화를 진행한다. 하지만 가끔 default 환경아닌 임의로 구성한 환경이라면? 예를 들어 com.example.myproject.web 가 root package:com.example.myproject 와 동일한 위치에 놓인다면?
com
+- example
+- myproject
+- Application.java
|
+- domain
| +- Customer.java
| +- CustomerRepository.java
|
+- service
| +- CustomerService.java
|
+- web
| +- CustomerController.java
|
이렇게 하면 Application.java 는 com.example.myproject.web 내의 Controller 를 자동으로 스캔할수 없고 마찬가지로 Controller를 초기화 할수 없다. 이때
@ComponentScan(basePackages="com.example")
를 추가하여 강제로 위치를 지정해 준다.
@SpringBootApplication
@ComponentScan(basePackages="com.example")
public class Bootstrap {
public static void main(String[] args) {
SpringApplication.run(Bootstrap.class, args);
}
}
또 다른 방법은 @Bean 어노테이션을 이용하는것
@SpringBootApplication
public class Bootstrap {
public static void main(String[] args) {
SpringApplication.run(Bootstrap.class, args);
}
@Bean
public CustomerController customerController() {
return new CustomerController();
}
}
뭐 어찌됐든 해결은 가능하나 현업에서는 이런 방식을 권장하지 않는다. 만일 팀장이나 초기 프로젝트 세팅하는 개발자가 이렇게 했다면 이글을 바탕으로 설명을 해주라!
끝!
내저장소 바로가기 luxury515
'Springboot2.x 강좌 > 로그의 기본설정' 카테고리의 다른 글
Logback설정 (1) | 2023.04.11 |
---|---|
TinyLog 사용하기 (0) | 2023.04.11 |