Spring/Spring tutorial - 코드로 배우는 스프링 (김영한)
비즈니스 요구 사항 정리
한둥둥
2022. 9. 17. 20:29
회원 관리 예제 - 백엔드 개발
비즈니스 요구사항 정리 : 회원 도메인과 리포지토리 만들기 ,회원 리포지토리, 테스트 케이스 작성, 회원 서비스 개발, 회원 서비스 테스트
비즈니스 요구사항 정리
데이터: 회원ID, 이름기능: 회원등록, 조회 아직 데이터 저장소가 선정되지 않음 (가상의 시나리오)
일반적인 웹 애플리케이션 계층 구조
- 컨트롤러: 웹 MVC의 컨트롤러 역할
- 서비스 : 핵심 비즈니스 로직 구현
- 리포지토리 : 데이터베이스에 접근, 도메인 객체를 DB에 저장하고 관리
- 도메인 : 비즈니스 도메인 객체 , 예) 회원, 주문, 쿠폰 등등 주로 데이터베이스에 저장하고 관리됨
아직 데이터 저장소가 선정되지 않아서, 우선 인터페이스로 구현 클래스를 변경할 수 있도록 설계 데이터 저장소는 RDB, NoSQL 등등 다양한 저장소를 고민중인 상황으로 가정개발을 진행하기 위해서 초기 개발 단계에서는 구현체로 가벼운 메모리 기반의 데이터 저장소 사용
회원을 저장하는 것은 인터페이스로 설계할 것이다. 아직 데이터 저장소가 선정되지 않았다.
우선적으로 구현체는 메모리 구현체로 만들것이다. 일단 개발은 해야되기 때문에 메모리에 단순히 저장하고 넣었다 뺄 수 있는 것을 만들것이다. 구체적인 기술이 필요하면 그때 가서 바꿔 끼울 것이다. 근데 바꿔끼우기 위해서는 인터페이스가 반드시 필요하기 때문에 인터페이스를 정의해준다.