728x90
Spring Framwork
Java Platform을 위한 오픈소스 애플리케이션 프레임워크로서 스프링( Spring ) 이라고 불린다.
- Open Source : 소프트웨어 혹은 하드웨어의 제작자의 권리를 지키면서 원시 코드를 누구나 열람할 수 있도록 한 소프트웨어로서 오픈 소스 라이센스에 준하는 모든 통칭을 말한다.
- Framework : 개발자를 위한 설계 기본의 뼈대, 구조, 환경을 말한다. ( 문제 영역을 해결한 재사용, 확장 가능한 라이브러리 )
Spring은 JAVA 기반의 Framwork이고 자바는 객체 지향 언어다.
(개발자인 우리는 좋은 객체 지향 프로그래밍이란 무엇인지 알아야한다.)
SOLID - 좋은 객체 지향 설계의 5가지 원칙
- SRP : 단일 책임 원칙 ( Single Responsibility Principle )
- 하나의 클래스는 하나의 책임만 갖는다.
- OCP : 개방 - 폐쇄 원칙 ( Open / Closed Principle )
- 확장에는 열려있으며 변경에는 닫혀있어야 한다.
- 기능을 추가하려면 코드의 수정은 불가피하며 다형성을 이용하더라도 클라이언트 코드를 변경해야 한다.
- LSK : 리스코프 치환 원칙 ( Liskov Substitution Principle )
- 프로그램의 객체는 프로그램의 정확성을 깨뜨리지 않으면서 하위 타입의 인스턴스로 바꿀 수 있어야 한다.
- 다형성에서 하위 클래스는 인터페이스 규약을 지켜야 한다.
- 다형성을 지원하기 위한 원칙, 인터페이스를 구현한 구현체는 믿고 사용하려면, 이 원칙이 필요하다.
- ISP : 인터페이스 분리 원칙 ( Interface Segregation Principle )
- 특정 클라이언트를 위한 여러 개의 인터페이스가 범용 인터페이스 단 하나보다 낫다.
- DIP : 의존관계 역전 원칙 ( Dependency inversion principle )
- 의존성 주입은 추상화에 의존해야하며, 구체화에 의존하면 안된다는 원칙을 따르는 방법 중 하나이다. ( 구현 클래스에 의존하지 말고 인터페이스에 의존하는 의미이다 )
스프링의 특징
- IOC ( Inversion of Control : 제어의 역행)
- 컨트롤의 제어권이 사용자가 아닌 프레임워크에 있어 필요에 따라 Spring에서 사용자의 코드를 호출한다.
- 애플리케이션 간의 느슨한 결합 도모
- DI ( Dependency Injection : 의존성 주입)
- 각각의 계층이나 서비스들 간에 의존성이 존재할 경우 프레임워크가 서로 연결시켜준다.
- 각각의 계층이나 서비스들 간에 의존성이 존재할 경우 프레임워크가 서로 연결시켜준다.
- AOP ( Aspect-Oriented Programming : 관점지향 프로그래밍 )
- Transaction이나 Logging, Security와 같이 여러 모듈에서 공통적으로 사용하는 기능의 경우 해당 기능을 분리하여 관리할 수 있다.
- AOP, Filter, Interceptor의 차이점을 알면 이해하기 쉽다. ( 다른 포스팅에서 다루겠습니다. )
- Container ( 컨테이너 )
- 애플리케이션 객체의 생명 주기와 설정을 포함하고 관리한다는 점에서 일종의
컨테이너
라고 부를 수 있다. - iBatis, MyBatis, Hibernate( JPA )등 완성도가 높은 데이터베이스처리 라이브러리와 연결할 수 있는 인터페이스를 제공한다.
- 애플리케이션 객체의 생명 주기와 설정을 포함하고 관리한다는 점에서 일종의
- Transaction Manage Framework
- 추상화된 트랜잭션 관리를 지원하며 설정파일 (xml, java, property 등)을 이용한 선언적인 방식 및 프로그래밍을 통한 방식을 모두 지원한다.
- Model-View-Controller 패턴 ( MVC )
- 웹 프로그래밍 개발 시 표준적인 방식인
Spring MVC
라 불리는 모델-뷰-컨트롤러 패턴을 사용한다. - DispatcherServlet이 Controller 역할을 담당하여 각종 요청을 적절한 서비스에 분산시켜주며 이를 각 서비스들이 처리하고 결과를 생성하여 다양한 형식의 View 서비스로 화면에 표시되는 패턴이다. ( MVC 패턴에도 다양한 패턴이 존재한다. )
- 웹 프로그래밍 개발 시 표준적인 방식인
- 배치 프레임워크 ( Batch Framework )
- 스프링은 특정 시간대에 실행하거나 대용량의 자료를 처리하는데 쓰이는 일괄 처리(Batch Processing)을 지원하는 배치 프레임워크를 제공한다. 스프링의 배치( Batch )는 Quartz 기반으로 동작한다.
스프링 모듈 ( Spring module )
- Spring Core
- Spring 프레임워크의 근간이 되는 요소. IOC, DI의 기능을 지원하는 영역을 담당한다.
- BeanFactory를 기반으로 Bean 클래스들을 제어할 수 있는 기능을 지원한다.
- Spring Context
- Spring Core 바로 위에 있는 계층으로 Spring Core에서 지원하는 기능 이외의 추가적인 기능들과 개발의 용이성을 제공한다.
- JNDI, EJB를 위한 Adaptor들을 포함
- Spring DAO
- 지금까지 우리들이 일반적으로 많이 사용해왔던 JDBC 기반하의 DAO개발을 좀 더 쉽고, 일관된 방법으로 개발하는 것이 가능하도록 지원한다.
- Spring DAO를 이용할 경우 지금까지 개발하던 DAO보다 적은 코드와 쉬운 방법으로 DAO를 개발하는 것이 가능하다.
- Spring ORM ( Object Relation Mapping )
- ORM Framework인 Hibernate, IBatis, JDO와의 결합을 지원하기 위한 기능이다.
- Spring ORM을 이용할 경우 Hibernate, IBatis, JDO 프레임워크와 쉽게 통합하는 것이 가능하다.
- Spring AOP ( Aspect Oriented Programming )
- AOP Alliance 기반하에서 개발하는 AOP를 지원하는 기능이다.
- Spring Web
- Web Application 개발에 필요한 Web Application Context와 Multipart Request등의 기능을 지원한다.
- Struts, Webwork와 같은 프레임워크의 통합을 지원한다.
- Spring Web MVC
- Spring Framework에서 독립적인 Web UI Layer에 Model-View-Controller를 지원하기 위한 기능이다.
느슨한 결합이란?
- 객체를 주입 받을 때 외부에서 생성된 객체를 인터페이스를 통해서 넘겨받는 것.
- 객체간의 결합도를 낮출 수 있으며, 런타임시에 의존관계가 결정되기 때문에 유연한 구조를 가진다.
강한 결합이란?
- 객체 내부에서 다른 객체를 생성하는 것은 강한 결합을 가지는 구조이다.
- ex) Class A 내부에서 Class B 객체를 직접 생성하고 있다면, B 객체는 C 객체로 바꾸고 싶은 경우에 A 클래스도 수정해야하는 방식이기 때문에 이를 강한 결합이라고 한다.
다음 포스팅에서는 Spring의 Filter, Interceptor, AOP를 비교하겠습니다.
728x90
'Backend > Spring' 카테고리의 다른 글
자주 사용되는 Spring 어노테이션에 대해 알아보자! (0) | 2022.01.21 |
---|---|
Spring AOP의 구동 원리와 Proxy와의 관계 (0) | 2022.01.13 |
AOP, Filter, Interceptor의 정의와 차이점 (3) - AOP편 (0) | 2022.01.11 |
AOP, Filter, Interceptor의 정의와 차이점 (2) - Interceptor 편 (0) | 2022.01.11 |
AOP, Filter, Interceptor의 정의와 차이점 (1) - Filter 편 (0) | 2022.01.10 |