디자인 패턴? 구현 SW 개발방법을 공식화 한것
1. MVC 패턴이란
Model & View & Controller 애플리 케이션을 3가지로 역할로 구분한 개발 방법론
모델 1. JSP(view) + javaBean(Service)
뷰와 로직이 섞인다
장점 | 단점 |
구조가 단순 |
출력과 로직 코드가 섞여 JSP코드가 복잡해진다 프런트와 백엔드가 혼재되어 분업이 용이하지 않다 유지보수가 어렵다. |
모델 2. [JavaBean(Service) + JSP(view) + 서블릿(controller)]
MVC구조
장점 | 단점 |
뷰와 로직의 분리로 모델1에 비해 덜 복잡하고, 분업이 용이하며, 유지보수가 쉽다. |
습득이 어렵고 작업량이 많다 |
MVC흐름
1. 사용자는 원하는 기능을 처리하기 위한 모든 요청을 컨트롤러에 보낸다.
2. 컨트롤러는 모델을 사용하고. 모델은 알맞은 비즈니스 로직을 수행한다.
3. 컨트롤러는 사용자에게 보여줄 뷰를 선택한다.
4. 선택된 뷰는 사용자에게 알맞는 결과 화면을 보여준다.
이때 사용자에게 보여줄 데이터는 컨트롤러를 통해서 전달받는다.
2. Model, View, Controller
Model - 값과 기능을 가지고 있는 객체
View - 모델에 포함된 데이터의 시각화
Controller - 모델 객체로의 데이터 흐름을 제어, 뷰와 모델의 역할을 분리
왜 MVC를 사용해야 하는가?
- 각 컴포넌트의 코드 결합도를 낮추기 위해
- 코드의 재사용성을 높이기 위해
- 구현자들 간의 커뮤니켄이션 효율성을 높이기 위해
실수 하는 부분들
- Model에서 View의 접근 또는 역할 수행
- View에서 일어나는 '과한' 값 검증과 예외 처리, 생성자(유효성 체크) -> 뷰, 논리자인값(존재 유무, 일치 여부) -> 서비스
- View에서 일어나는 비즈니스 로직 , 단일 책임 원칙!
Controller 에서 중복 발생 -> 별도의 객체로 분리, 별도의 메서드로 분리
3. Service
비지니스 로직을 수행하는 메서드를 가지고 있는 객체
비지니스 메서드를 별도의 Service 객체에서 구현하도록하고 컨트롤러는 Service 객체를 사용하도록 한다.
Transaction
특징 : ACID
1. 원자성 : 하나의 원자 트랜잭션은 모두 성공 or 모두 실패
2. 일관성 : 트랜잭션 작업처리 결과가 항상 일관성 있어야한다.
3. 독립성 : 어느 하나의 트랜잭션이라도 다른 트랜잭션의 연산에 끼얼들 수 없다.
4. 지속성 : 트랜잭션이 성곡적으로 완료 되었을 경우, 결과는 영구적으로 반영되어야 한다.
4. Repository(DAO, Data Acess Object)
데이터 액세스 메서드를 별도의 Repository 객체에서 구현
Service는 Repository 객체를 사용
www.youtube.com/watch?v=uoVNJkyXX0I&list=PLgXGHBqgT2TvpJ_p9L_yZKPifgdBOzdVH&index=90
'Back-end > 디자인패턴' 카테고리의 다른 글
디자인 패턴 입문 (0) | 2021.11.13 |
---|---|
OCP 와 전략 패턴 (0) | 2021.04.23 |