티스토리 뷰
JSP란?
JSP는 Java Server Pages의 약자로, 서버 측에서 동적 웹 페이지를 생성하기 위해 사용되는 기술이다. JSP는 HTML 문서 안에 Java 코드를 삽입하여 웹 페이지를 동적으로 생성할 수 있게 해 준다.
JSP와 HTML의 차이점
HTML과의 가장 큰 차이점은 JSP에서는 Java 코드를 사용할 수 있다는 것이다. JSP는 서버 측에서 실행되고 동적인 기능을 처리하는 반면, HTML은 클라이언트 측에서 실행되고 정적인 페이지의 구조를 표현한다. JSP는 Java 코드를 사용하여 데이터 처리와 로직을 구현할 수 있으며, 서버에서 동적인 데이터를 생성하여 클라이언트에게 전달한다. HTML은 단순히 페이지의 구조와 내용을 정의하는 역할을 한다.
JSP는 서버 사이드 스크립트 언어이므로, 서버 측에서 실행되는 로직과 데이터베이스와의 상호작용 등을 처리할 수 있다. HTML은 클라이언트 측에서 실행되므로, 사용자 인터페이스와 상호작용을 위한 기능을 구현하는 데 주로 사용된다.
이러한 차이점으로 인해 JSP와 HTML은 서로 보완적으로 사용되며, 백엔드와 프론트엔드 간의 협업을 통해 동적이고 상호작용이 가능한 웹 애플리케이션을 개발할 수 있다.
JSP 동작 원리
- 클라이언트(웹 브라우저)가 JSP 페이지를 요청한다.
- JSP 컨테이너(서블릿 컨테이너)는 해당 JSP 페이지를 서블릿으로 변환한다. 이 서블릿은 Java 코드로 작성되며, 동적인 데이터 처리와 HTML 생성을 수행한다.
- 서블릿은 컴파일된 후에 실행 가능한 형태로 만들어진다.
- 서블릿이 생성된 후에는 요청된 JSP 페이지에 대한 응답을 처리하기 위해 실행된다.
- 서블릿은 필요한 데이터를 처리하고, Java 코드 내에 포함된 HTML 템플릿과 함께 최종적인 HTML 페이지를 생성한다.
- 생성된 HTML은 클라이언트로 전달되어 웹 브라우저에 응답으로 표시된다.
이 과정에서 JSP 컨테이너는 JSP 파일의 Java 코드 부분을 서블릿으로 변환하고, 서블릿을 실행하여 필요한 데이터 처리와 HTML 생성을 수행한다. 이를 통해 동적인 데이터를 처리하고 HTML을 생성하는 것이 가능해진다.
JSP는 Java 코드와 HTML을 혼합하여 작성되므로, Java 코드 부분은 <% %>
태그로 감싸져 있다. JSP 컨테이너는 이 태그 내의 Java 코드를 실행하여 동적인 데이터 처리를 수행하고, 그 결과를 HTML로 변환하여 클라이언트에게 전달한다.
자바 프로젝트 디렉터리 구조 예시
자바 프로젝트의 일반적인 디렉토리 구조는 다음과 같다. 프로젝트의 규모와 구성에 따라 조금씩 달라질 수 있다.
프로젝트명
├── src
│ ├── main
│ │ ├── java
│ │ │ └── 패키지명
│ │ │ └── 소스 파일들.java
│ │ └── resources
│ │ └── 설정 파일들, 리소스 파일들
│ └── test
│ ├── java
│ │ └── 패키지명
│ │ └── 테스트 소스 파일들.java
│ └── resources
│ └── 테스트 설정 파일들, 리소스 파일들
├── WebContent 또는 webapp
│ ├── WEB-INF
│ │ ├── lib
│ │ │ └── 라이브러리 파일들.jar
│ │ ├── classes
│ │ │ └── 컴파일된 클래스 파일들
│ │ └── web.xml
│ └── JSP 파일들, CSS 파일들, JavaScript 파일들, 이미지 파일들 등
└── pom.xml 또는 build.gradle (빌드 도구 설정 파일)
JSP 파일들은 WebContent
또는 webapp
디렉터리에 위치한다. 이 디렉토리는 웹 애플리케이션의 루트 디렉토리로서, 클라이언트(웹 브라우저)에게 제공되는 웹 리소스들을 포함한다. JSP 파일은 해당 디렉토리 내에 위치하며, 프론트엔드 개발자가 주로 작업하는 영역이다. 프론트엔드 개발자는 JSP 파일을 통해 HTML, CSS, JavaScript 등을 작성하여 웹 페이지의 디자인과 동적인 기능을 구현할 수 있다.
웹 애플리케이션의 구성 파일인 web.xml
은 WEB-INF
디렉토리에 위치한다. 이 파일은 서블릿 컨테이너에게 웹 애플리케이션의 구성 정보를 제공하는 역할을 한다.
이와 같은 디렉토리 구조는 Java 프로젝트에서 백엔드와 프론트엔드 간의 협업을 용이하게 하고, 코드와 리소스의 관리를 효과적으로 할 수 있도록 한다.
JSTL 라이브러리
JSTL(JavaServer Pages Standard Tag Library)은 JSP를 보다 효율적으로 개발하기 위해 제공되는 라이브러리다. JSTL은 JSP에서 반복문, 조건문, 변수 설정 등과 같은 일반적인 작업을 수행하기 위한 태그들의 집합이다. JSP에서 스크립트릿(<% %>
) 태그를 사용하지 않고도 JSTL 태그를 활용하여 작업을 수행할 수 있다.
JSTL을 사용하면 JSP 코드의 가독성과 유지보수성이 향상되며, 개발자는 더욱 효율적으로 JSP를 개발할 수 있다. JSTL은 Java 표준으로 정의되어 있어 다양한 JSP 컨테이너에서 지원된다.
JSTL은 여러 가지 기능을 제공하는 태그 라이브러리로 구성되어 있다. 예를 들어, c:forEach
태그는 컬렉션을 반복하면서 값을 처리할 수 있고, c:if
태그는 조건문을 수행할 수 있다. 이 외에도 c:set
, c:choose
, c:when
, c:otherwise
등 다양한 태그들이 있어 JSP에서 보다 간편하고 가독성 높은 코드를 작성할 수 있게 도와준다.
JSP만 사용한 코드
<%@ page contentType="text/html; charset=UTF-8" %>
<!DOCTYPE html>
<html>
<head>
<title>순수 JSP 예시</title>
</head>
<body>
<h1>회원 목록</h1>
<%
// 회원 목록 데이터
String[] members = {"John", "Jane", "Tom"};
%>
<ul>
<% for (String member : members) { %>
<li><%= member %></li>
<% } %>
</ul>
</body>
</html>
JSTL을 사용한 코드
<%@ page contentType="text/html; charset=UTF-8" %>
<%@ taglib prefix="c" uri="<http://java.sun.com/jsp/jstl/core>" %>
<!DOCTYPE html>
<html>
<head>
<title>JSTL 예시</title>
</head>
<body>
<h1>회원 목록</h1>
<c:set var="members" value="${['John', 'Jane', 'Tom']}" />
<ul>
<c:forEach items="${members}" var="member">
<li>${member}</li>
</c:forEach>
</ul>
</body>
</html>
렌더링 순서
백엔드와 프론트엔드가 Java, JSP, CSS, JavaScript로 협업할 때의 렌더링 순서는 다음과 같다.
- 클라이언트(웹 브라우저)가 서버로 웹 페이지를 요청한다.
- 요청은 백엔드(Java)로 전달된다.
- 백엔드에서는 요청에 따라 필요한 데이터 처리와 비즈니스 로직을 수행한다.
- 백엔드는 데이터와 함께 JSP 파일을 호출하여 HTML을 생성한다.
- JSP 파일은 Java 코드와 HTML을 포함하고 있으며, 동적인 데이터 처리와 HTML 생성을 담당한다.
- JSP 파일 내에서 생성된 HTML은 클라이언트로 응답된다.
- 클라이언트는 받은 HTML을 웹 브라우저에서 해석하고 렌더링 한다.
- 렌더링 된 HTML은 화면에 보이며, 이때 CSS 스타일 시트를 적용하여 페이지의 디자인을 결정한다.
- 클라이언트(웹 브라우저)는 JavaScript 코드를 해석하고 실행하여 동적인 기능을 구현한다.
- 사용자의 상호작용에 따라 JavaScript를 통해 HTML이 동적으로 변경되거나 이벤트가 처리된다.
백엔드는 데이터 처리와 비즈니스 로직을 담당하고, JSP를 통해 HTML을 생성하여 클라이언트에게 전달한다. 클라이언트는 HTML을 해석하고 렌더링 하며, CSS를 적용하여 디자인을 결정하고 JavaScript를 실행하여 동적인 기능을 구현한다. 이를 통해 완성된 웹 페이지가 사용자에게 제공되는 것이다.
JSP 사용 이유
JSP는 Java 기반으로 작성되기 때문에 Java의 강력한 기능과 라이브러리를 활용할 수 있다. 또한 정적인 웹 페이지를 생성하는 HTML로는 동적인 값을 적용하는 데는 제한이 있는데, (ex. 사용자의 입력이나 데이터베이스의 정보를 받아와서 동적으로 웹 페이지를 생성해야 할 때) JSP에서는 Java 코드를 활용하여 동적인 값을 적용할 수 있기 때문에 더욱 유연하고 다양한 기능을 구현할 수 있다.
JSP 단점
- 디자인과 로직의 분리: JSP는 서버 사이드 스크립트 언어로써, Java 코드와 HTML이 혼재하여 작성된다. 이로 인해 디자인과 로직이 분리되지 않고 섞이는 경향이 있어서 유지보수와 협업을 어렵게 할 수 있다.
- 가독성과 유지보수: JSP 파일이 복잡해지면 가독성이 떨어지고 유지보수가 어려워질 수 있다. JSP 파일 안에 많은 양의 Java 코드가 포함되면서 코드의 복잡도가 증가할 수 있다.
- 테스트와 디버깅: JSP는 서버 측에서 실행되기 때문에 로컬 환경에서의 테스트와 디버깅이 어려울 수 있다. JSP 파일의 코드와 HTML이 혼재하므로 디버깅에 어려움을 겪을 수 있다.
- 성능: JSP는 동적인 웹 페이지를 생성하기 위해 서버 측에서 실행되기 때문에 서버의 부하가 발생할 수 있다. 특히 매 요청마다 JSP 파일이 다시 컴파일되고 실행되어야 하는 단점이 있다.
- 확장성과 유연성: JSP는 Java 기반으로 동작하기 때문에 Java의 제약사항과 의존성을 가지고 있다. 이로 인해 다른 언어나 프레임워크와의 통합이 어려울 수 있고, 확장성과 유연성이 제한될 수 있다.
이러한 단점들은 JSP를 사용할 때 고려해야 할 사항이다. 최근에는 JSP 대신에 프론트엔드 프레임워크와 API 방식을 활용하여 더 유연하고 모던한 웹 애플리케이션을 개발하는 추세이다.
최신 동향
요즘에는 JSP 외에도 프론트엔드 자체에서 동적으로 작업할 수 있는 언어 및 기술들이 많이 등장하고 있다.
JavaScript를 비롯한 클라이언트 사이드 스크립트 언어들은 웹 브라우저에서 동적인 기능을 구현하는 데 많이 활용된다. JavaScript를 사용하여 웹 페이지의 동적인 요소를 제어하고, AJAX를 통해 비동기적으로 데이터를 가져오고 업데이트하는 등의 작업을 수행할 수 있다. 이로 인해 프론트엔드 개발자들은 서버와의 상호작용이나 데이터 처리를 클라이언트 측에서 직접 처리할 수 있게 되었다.
또한, 프론트엔드 프레임워크와 라이브러리들이 발전하면서 동적인 웹 애플리케이션 개발을 위한 다양한 선택지가 생겨났다. 대표적인 예시로는 React, Vue.js, Angular 등이 있다. 이러한 프론트엔드 프레임워크들은 가상 DOM을 활용하여 UI 컴포넌트를 동적으로 조작하고 업데이트할 수 있게 해 준다.
또한, RESTful API를 활용하여 클라이언트와 서버 간의 데이터 통신을 처리하는 방식도 널리 사용되고 있다. 이를 통해 클라이언트는 데이터를 비동기적으로 요청하고 서버로부터 데이터를 받아와 동적으로 웹 페이지를 업데이트할 수 있다.
이러한 동적 웹 개발 방법들은 프론트엔드 개발자가 독립적으로 서버와 상호작용하고 데이터 처리를 수행할 수 있는 환경을 제공한다.
'Java' 카테고리의 다른 글
[Java] Spring Boot - Gradle 프로젝트 빌드하고 실행하기 (0) | 2022.10.04 |
---|---|
[Java] 피보나치(fibonacci) 수열을 반복 함수, 재귀 함수로 연산하기 + 재귀 함수의 단점 (0) | 2022.09.28 |
[Java] Servlet(서블릿) (0) | 2022.08.09 |
[Java] JSP(Java Server Pages) 정리 (0) | 2022.08.08 |