POJO(Plain Old Java Object)

seongmin·2022년 10월 11일
0

Spring

목록 보기
4/38
post-thumbnail
post-custom-banner

POJO라는 것을 IoC/DI, AOP, PSA를 통해서 달성할 수 있다는 것을 의미한다.

POJO 에서 POJava로 생성하는 순수한 객체를 의미한다.

POJO

POJO 프로그래밍이란 POJO를 이용해서 프로그래밍 코드를 작성하는 것을 의미한다.

POJO 프로그래밍으로 작성한 코드라고 불리우기 위해서는 크게 두 가지 정도의 기본적인 규칙은 지켜야 한다.

  • Java나 Java의 스펙(사양)에 정의된 것 이외에는 다른 기술이나 규약에 얽매이지 않아야 한다.
public class User {
  private String userName;
  private String id;
  private String password;

  public String getUserName() {
    return userName;
  }

  public void setUserName(String userName) {
  	this.userName = userName;
  }

  public String getId() {
  	return id;
  }

  public void setId(String id) {
  	this.id = id;
  }

  public String getPassword() {
  	return password;
  }

  public void setPassword(String password) {
  	this.password = password;
  }
}

위 코드는 자바에서 제공하는 기능만 사용하여 getter , setter 만 가지고 있는 코드다. 해당 클래스의 코드에서는 Java 언어 이외에 특정한 기술에 종속되어 있지 않은 순수한 객체이기 때문에 POJO라고 부를 수 있다.

public class MessageForm extends ActionForm{ // (1)
	
	String message;

	public String getMessage() {
		return message;
	}

	public void setMessage(String message) {
		this.message = message;
	}
	
}

public class MessageAction extends Action{ // (2)
	
	public ActionForward execute(ActionMapping mapping, ActionForm form,
		HttpServletRequest request, HttpServletResponse response)
        throws Exception {
		
		MessageForm messageForm = (MessageForm) form;
		messageForm .setMessage("Hello World");
		
		return mapping.findForward("success");
	}
	
}

ActionForm 클래스는 과거에 Struts라는 웹 프레임워크에서 지원하는 클래스다.
(1)에서는 Struts라는 기술을 사용하기 위해서 ActionForm을 상속하고 있다.
(2)에서는 역시 Struts 기술의 Action 클래스를 상속 받고 있다.

이렇게 특정 기술을 상속 해서 코드를 작성하게 되면 나중에 애플리케이션의 요구사항이 변경되서 다른 기술로 변경하려면 Struts의 클래스를 명시적으로 사용했던 부분을 전부 다 일일이 제거하거나 수정해야한다.

그리고, Java는 다중 상속을 지원하지 않기 때문extends 키워드를 사용해서 한 번 상속을 하게되면 상위 클래스를 상속받아서 하위 클래스를 확장하는 객체지향 설계 기법을 적용하기 어려워지게 된다.

  • 특정 환경에 종속적이지 않아야 한다.

순수 Java로 작성한 애플리케이션 코드내에서 Tomcat 이 지원하는 API를 직접 가져다가 사용한다고 가정한다.

그런데 만약에 시스템의 요구 사항이 변경되어서 Tomcat 말고 제티(Zetty) 라는 다른 Servlet Container를 사용하게 된다면 어떻게 될까?

애플리케이션 코드에서 사용하고 있는 Tomcat API 코드들을 모두 걷어내고 Zetty로 수정하든가 최악의 경우에는 애플리케이션을 전부 뜯어 고쳐야될지도 모르는 상황에 직면하게 될 수 있다.

필요한 이유

  • 특정 환경이나 기술에 종속적이지 않으면 재사용 가능하고, 확장 가능한 유연한 코드를 작성할 수 있다.
  • 저수준 레벨의 기술과 환경에 종속적인 코드를 애플리케이션 코드에서 제거 함으로써 코드가 깔끔해진다.
  • 코드가 깔끔해지기 때문에 디버깅하기도 상대적으로 쉽다.
  • 특정 기술이나 환경에 종속적이지 않기 때문에 테스트 역시 단순해진다.
  • 객체지향적인 설계를 제한없이 적용할 수 있다.(가장 중요한 이유)

Key Point

  • POJO란 순수한 Java 객체를 의미한다.
  • POJO 프로그래밍이란 순수 Java 객체가 다른 기술이나 환경에 종속되지 않도록 하기 위한 프로그래밍 기법이다.
  • POJO 프로그래밍을 효과적으로 적용하기 위해서는 특정 기술에 대한 지식보다는 JDK의 API에 대한 지식과 객체지향적인 사고방식과 설계를 위한 훈련이 우선시 되어야 한다.
  • Spring Framework은 POJO 프로그래밍을 지향하기 위해 IoC/DI, AOP, PSA 라는 기술을 제공한다.

  • 객체 지향 설계 원칙

SOLID(객체 지향 설계 원칙): https://ko.wikipedia.org/wiki/SOLID(객체지향_설계)
SOLID 요약: https://itvillage.tistory.com/entry/객체지향-설계-원칙-SOLID-원칙

POJO와 Spring의 관계

프로젝트가 커지고 필요한 기술들이 늘어나며 특정한 기술과 환경에 종속되는 경우가 자주 발생하여 작성된 코드의 유지/보수가 어렵고 특정 클래스를 상속받게 되어 기능의 확장이 어려운 경우가 많이 생겼다. 좋은 객체지향 설계를 할 수 있는 Java언어를 사용하면서도 결국 객체지향 설계 본질을 잃어버리는 문제점들을 해결하고자 POJO라는 개념이 등장하게 되었다.

Spring은 POJO 프로그래밍을 지향하는 Framework 이다.

그리고 최대한 다른 환경이나 기술에 종속적이지 않도록 하기 위한 POJO 프로그래밍 코드를 작성하기 위해서 Spring에서는 세가지 기술을 지원하고 있다.

그 세가지 기술은 IoC/DI , AOP , PSA 다.

post-custom-banner

0개의 댓글