jsp시험

최현주·2023년 11월 14일
1

웹 어플리케이션 서버와 앱 서버 차이점

웹 어플리케이션 서버(Web Application Server)와 앱 서버(Application Server)는 비슷한 개념으로 사용되기도 하지만, 일반적으로는 다른 맥락에서 사용되곤 합니다. 아래는 두 용어 간 주요 차이점입니다.

용어 사용 맥락:

웹 어플리케이션 서버(Web Application Server): 주로 웹 어플리케이션의 실행 환경을 제공하는 서버를 가리킵니다. 이 서버는 클라이언트의 요청을 받아들이고, 비즈니스 로직을 실행하며, 결과를 클라이언트에게 반환합니다. 웹 어플리케이션 서버는 웹 애플리케이션의 동적인 부분을 처리하고 데이터베이스와의 상호 작용을 관리합니다.
앱 서버(Application Server): 이 용어는 주로 기업 환경에서 사용되며, 엔터프라이즈 애플리케이션을 실행하는 데 중점을 둡니다. 앱 서버는 다양한 엔터프라이즈 애플리케이션의 구성 요소를 관리하고, 분산 환경에서의 통신 및 상호 운용성을 지원합니다.
주된 역할:

웹 어플리케이션 서버(Web Application Server): 주로 웹 애플리케이션의 동적인 처리를 담당합니다. 클라이언트의 요청을 받아들이고, 비즈니스 로직을 실행하며, 동적인 콘텐츠를 생성하여 클라이언트에게 제공합니다.
앱 서버(Application Server): 엔터프라이즈 애플리케이션을 실행하기 위한 환경을 제공합니다. 이는 특정 업무 프로세스나 비즈니스 로직을 처리하고, 데이터베이스와의 상호 작용을 관리합니다.
서비스 지원:

웹 어플리케이션 서버(Web Application Server): 클라이언트-서버 모델에서 주로 웹 브라우저를 통한 클라이언트와의 상호 작용을 다룹니다. 주로 HTTP 프로토콜을 통해 통신합니다.
앱 서버(Application Server): 엔터프라이즈 애플리케이션 간의 통신 및 상호 작용을 관리하며, 분산된 환경에서의 서비스 지원을 중시합니다.
사용 분야:

웹 어플리케이션 서버(Web Application Server): 주로 웹 애플리케이션의 구축과 운영에 사용됩니다.
앱 서버(Application Server): 기업 환경에서 다양한 엔터프라이즈 애플리케이션의 실행을 지원하며, 특히 분산된 환경에서의 통신과 트랜잭션 처리를 강조합니다.
요약하면, 웹 어플리케이션 서버는 주로 웹 애플리케이션을 위한 것이며, 앱 서버는 엔터프라이즈 애플리케이션 실행과 분산된 환경에서의 통신을 위한 것입니다.

jsp 내장객체 종류

JavaServer Pages(JSP)는 서버 측에서 동적인 웹 페이지를 생성하기 위한 기술로, JSP 페이지 내에서 사용할 수 있는 여러 내장 객체가 있습니다. 이러한 내장 객체들은 JSP 페이지의 스코프에서 사용할 수 있으며, 주로 서버 측 로직과 클라이언트 측과의 상호 작용을 지원합니다. 아래는 주요한 JSP 내장 객체들입니다:

request:

클라이언트로부터의 HTTP 요청에 대한 정보를 저장하는 객체입니다. 요청 매개변수, 헤더, 쿠키 등의 정보에 접근할 수 있습니다.
jsp
Copy code
<%= request.getParameter("paramName") %>
response:

클라이언트로의 HTTP 응답을 생성하는 데 사용되는 객체입니다. 클라이언트에게 데이터를 출력하거나 리다이렉션을 수행하는 데 사용됩니다.
jsp
Copy code
<%= response.encodeURL("someURL") %>
out:

클라이언트로의 출력 스트림을 나타내는 객체로, HTML이나 텍스트와 같은 컨텐츠를 출력하는 데 사용됩니다.
jsp
Copy code
<% out.println("Hello, JSP!"); %>
session:

클라이언트와 서버 간의 세션을 관리하는 객체로, 세션 데이터를 저장하고 검색하는 데 사용됩니다.
jsp
Copy code
<% session.setAttribute("username", "user123"); %>
application:

웹 애플리케이션 전체에서 유효한 데이터를 저장하고 검색하는 데 사용되는 객체입니다.
jsp
Copy code
<% application.setAttribute("globalData", "someValue"); %>
config:

JSP 페이지의 설정 정보에 접근하는 데 사용되는 객체입니다.
jsp
Copy code
<%= config.getServletContext().getInitParameter("parameterName") %>
pageContext:

JSP 페이지의 모든 영역에 대한 컨텍스트 정보에 접근하는 데 사용되는 객체입니다.
jsp
Copy code
<% pageContext.setAttribute("attributeName", "attributeValue"); %>
page:

현재 JSP 페이지를 나타내는 객체로, 주로 페이지 지시자(<%@ page %>)에서 import나 contentType 등의 속성을 설정하는 데 사용됩니다.
jsp
Copy code
<%@ page contentType="text/html;charset=UTF-8" %>
이러한 내장 객체들은 JSP 페이지에서 사용할 수 있는 다양한 정보에 접근하고 서버 측 로직을 처리하는 데 유용합니다.

sendredirect방식과 forward방식

sendRedirectforward는 Java 웹 프로그래밍에서 서버 측에서 클라이언트로의 페이지 이동을 다루는 데 사용되는 두 가지 주요 방식입니다.

1. sendRedirect:

  • 특징:
    • 클라이언트 측에서의 요청과 응답이 두 번 발생합니다.
    • 새로운 요청이 발생하므로 URL이 변경됩니다.
    • 클라이언트에서 새로운 URL로 이동하며, 이때 새로운 요청이 서버에 도달합니다.
  • 사용 예시:
    response.sendRedirect("newPage.jsp");
  • 활용:
    • 사용자가 어떤 페이지를 요청했지만, 그 요청을 다른 페이지로 리다이렉트하고자 할 때 사용됩니다.
    • 주로 외부 URL로 이동할 때 사용됩니다.
  • 장점 및 주의 사항:
    • 새로운 요청이 발생하므로 클라이언트에서의 URL이 변경되어 브라우저에서도 확인할 수 있습니다.
    • 클라이언트에게 완전히 새로운 페이지로 이동하는 것이므로, 이전 페이지의 상태를 그대로 유지하기 어렵습니다.

2. forward:

  • 특징:

    • 클라이언트에게는 아무런 통지 없이 서버 내에서만 페이지가 이동됩니다.
    • 단일 요청과 응답이 이루어집니다.
  • 사용 예시:

    RequestDispatcher dispatcher = request.getRequestDispatcher("newPage.jsp");
    dispatcher.forward(request, response);
  • 활용:

    • 현재 실행 중인 서블릿이나 JSP 페이지에서 다른 서블릿이나 JSP 페이지로 작업을 위임하고자 할 때 사용됩니다.
    • 서버 내의 다른 자원으로 이동할 때 사용됩니다.
  • 장점 및 주의 사항:

    • 클라이언트에게는 어떠한 변화도 없이 서버 내에서만 페이지 이동이 이루어지므로, URL이 변경되지 않습니다.
    • 단일 요청 및 응답이기 때문에 서버 내에서의 처리만으로 페이지 이동이 이루어지므로, 성능상의 이점이 있을 수 있습니다.

비교:

  • 공통점:

    • 둘 다 페이지 간 이동을 담당하는데 사용됩니다.
    • 둘 다 RequestDispatcher를 사용하여 구현됩니다.
  • 차이점:

    • sendRedirect는 완전히 새로운 요청이 발생하며 클라이언트에서 URL이 변경됩니다.
    • forward는 클라이언트에게 아무런 변화 없이 서버 내에서 페이지 이동이 이루어지며, 단일 요청과 응답이 이루어집니다.

    웹 서버 프로그램을 사용하는 이유

    웹 서버 프로그램은 웹 환경에서 웹 페이지, 이미지, 동영상 등의 리소스를 제공하고, 클라이언트로부터의 요청에 응답하는 역할을 하는 소프트웨어입니다. 이러한 웹 서버 프로그램을 사용하는 이유는 여러 가지가 있습니다.

  1. 클라이언트-서버 아키텍처: 웹 서버는 클라이언트와 서버 간의 효율적인 통신을 지원하여 클라이언트는 필요한 리소스를 서버에서 받아올 수 있습니다. 이를 통해 사용자는 웹 브라우저를 통해 쉽게 웹 페이지를 열람하고 상호작용할 수 있습니다.

  2. 리소스 제공: 웹 서버는 정적인 웹 페이지나 이미지, 스타일 시트, 자바스크립트 파일 등의 정적 파일들을 제공합니다. 이를 통해 클라이언트는 서버에서 필요한 리소스를 요청하여 받아올 수 있습니다.

  3. 동적 콘텐츠 생성: 웹 서버는 동적인 웹 페이지를 생성하기 위해 서버 사이드 스크립팅 언어(예: PHP, Python, Ruby)를 실행하고 그 결과를 클라이언트에게 제공합니다. 이를 통해 사용자에게 맞춤형 콘텐츠를 동적으로 생성할 수 있습니다.

  4. 안전성 및 보안: 웹 서버는 다양한 보안 기능을 제공하여 웹 애플리케이션 및 데이터를 보호합니다. SSL/TLS를 이용한 암호화, 웹 방화벽, 접근 제어 등의 기능을 통해 보안을 강화할 수 있습니다.

  5. 로드 밸런싱: 로드 밸런싱은 여러 웹 서버 간에 트래픽을 분산하여 성능을 향상시키는 기술을 말합니다. 웹 서버 프로그램을 사용하면 이러한 로드 밸런싱을 구현하여 효율적인 서비스를 제공할 수 있습니다.

  6. 로그 기록: 웹 서버는 클라이언트의 요청과 서버의 응답에 대한 로그를 기록하여 이를 분석함으로써 서버 동작을 모니터링하고 문제를 식별하는 데 도움을 줍니다.

  7. 인증과 세션 관리: 웹 서버는 사용자의 인증을 처리하고 세션을 관리하여 사용자가 로그인한 상태를 유지하거나 특정 작업을 수행하는 데 필요한 정보를 저장합니다.

이러한 이유들로 웹 서버 프로그램은 웹 환경에서 안정적이고 효율적인 서비스를 제공하는 핵심적인 구성 요소로 사용됩니다.

Url Mapping의 의미와 사용하는 이유

URL Mapping은 웹 어플리케이션에서 요청된 URL을 특정한 리소스나 기능으로 연결시키는 프로세스를 가리킵니다. 간단하게 말하면, 어떤 URL이 어떤 기능이나 리소스와 연결되는지를 정의하는 것입니다. 이는 주로 웹 프레임워크나 서버에서 사용되며, 다양한 목적으로 활용됩니다.

URL Mapping의 의미:

  1. 리소스 지정: 특정 URL이 특정 파일, 디렉토리, 또는 서버 측 로직과 연결되도록 지정합니다. 예를 들어, "/about" URL이 "about.html" 파일이나 서버 측 로직에 매핑될 수 있습니다.

  2. RESTful 서비스: URL Mapping은 RESTful 서비스에서 HTTP 동작(GET, POST, PUT, DELETE 등)과 리소스 간의 매핑을 정의하는 데 사용됩니다. 각 URL은 특정 동작을 수행하고자 하는 리소스를 가리킵니다.

  3. 파라미터 전달: URL Mapping을 사용하면 URL에 포함된 파라미터를 추출하고, 이를 기반으로 특정한 동작이나 데이터 처리를 수행할 수 있습니다.

URL Mapping을 사용하는 이유:

  1. 모듈화 및 구조화: URL Mapping을 사용하면 코드를 모듈화하고 구조화할 수 있습니다. 특정 URL에 대한 처리 로직이나 리소스가 어디에 위치하는지 명확하게 정의함으로써 코드의 가독성과 유지보수성을 높일 수 있습니다.

  2. 유연성: 어플리케이션의 URL 구조를 손쉽게 변경하거나 업그레이드할 수 있습니다. 새로운 기능을 도입하거나 기존 기능을 수정할 때, URL Mapping을 통해 새로운 URL과 기능을 연결시킬 수 있습니다.

  3. RESTful 서비스 지원: RESTful 서비스에서는 각 URL이 특정 동작과 리소스를 매핑하므로, 클라이언트와 서버 간의 통신이 효율적이고 일관성 있게 이루어집니다.

  4. SEO (Search Engine Optimization): 검색 엔진 최적화를 위해 URL이 의미 있고 직관적이어야 합니다. URL Mapping을 통해 의미 있는 URL을 사용하면 검색 엔진이 해당 페이지의 콘텐츠를 더 잘 이해하고 색인화할 수 있습니다.

  5. 보안: URL Mapping을 사용하여 특정 URL에 접근 권한을 부여하거나 제한함으로써 보안을 강화할 수 있습니다.

URL Mapping은 웹 어플리케이션의 구조를 정의하고 사용자 및 개발자 간의 경험을 향상시키는 데에 중요한 역할을 합니다.

웹 프로그래밍을 하기 위해 WAS로 톰캣(Tomcat)을 사용했을 때에, 사용할 웹 포트번호를 변경하거나 URL인코딩 방식을 바꿀 때에 수정해야 하는 파일명은 무엇인가?

톰캣(Tomcat)을 사용하여 웹 프로그래밍을 할 때, 웹 포트번호를 변경하거나 URL 인코딩 방식을 수정해야 하는 파일은 server.xml입니다.

  1. 웹 포트번호 변경:

    • 해당 설정은 주로 <Connector> 엘리먼트에서 수행됩니다. server.xml 파일에서 <Connector> 엘리먼트를 찾아서 port 속성 값을 수정하여 포트번호를 변경할 수 있습니다.

    예시:

    <Connector port="8080" protocol="HTTP/1.1"
               connectionTimeout="20000"
               redirectPort="8443" />

    여기서 port 속성을 원하는 포트번호로 변경하면 됩니다.

  2. URL 인코딩 방식 변경:

    • URL 인코딩 방식은 주로 <Connector> 엘리먼트의 URIEncoding 속성에서 설정됩니다. 이를 수정하여 URL 인코딩 방식을 변경할 수 있습니다.

    예시:

    <Connector port="8080" protocol="HTTP/1.1"
               connectionTimeout="20000"
               redirectPort="8443"
               URIEncoding="UTF-8" />

    URIEncoding 속성을 원하는 인코딩으로 변경하면 됩니다.

위의 설정 변경 후에는 톰캣 서버를 재시작해야 새로운 설정이 적용됩니다. 변경 사항을 적용하기 전에 server.xml 파일을 수정하기 전에 백업하는 것이 좋습니다.

request.getParameter() 와 request.getParameterValues()의 차이점

request.getParameter()request.getParameterValues()는 서블릿에서 클라이언트로부터 전송된 HTTP 요청의 매개변수를 가져오기 위한 메서드입니다. 그러나 이 두 메서드 간에는 몇 가지 중요한 차이가 있습니다.

  1. request.getParameter(name)

    • 이 메서드는 주어진 이름(name)에 해당하는 매개변수의 첫 번째 값을 반환합니다.
    • 만약 해당 이름의 매개변수가 없다면 null을 반환합니다.
    • 주로 단일 값을 전달하는 경우에 사용됩니다. 예를 들어, 폼에서 하나의 입력 필드의 값을 가져올 때 사용할 수 있습니다.
    String parameterValue = request.getParameter("parameterName");
  2. request.getParameterValues(name)

    • 이 메서드는 주어진 이름(name)에 해당하는 매개변수의 모든 값을 배열로 반환합니다.
    • 만약 해당 이름의 매개변수가 없다면 null이 아닌 빈 배열을 반환합니다.
    • 주로 하나의 이름에 여러 값을 전달하는 경우에 사용됩니다. 예를 들어, 체크박스 그룹이나 여러 선택을 허용하는 드롭다운 메뉴에서 사용될 수 있습니다.
    String[] parameterValues = request.getParameterValues("parameterName");

예시:
가정하고 HTML 폼이 다음과 같다고 가정해봅시다:

<form method="post" action="/servletURL">
    <input type="text" name="singleValue" value="Single Value">
    <input type="checkbox" name="multipleValues" value="Value1"> Value 1
    <input type="checkbox" name="multipleValues" value="Value2"> Value 2
    <input type="submit" value="Submit">
</form>

서블릿에서 이러한 값을 가져오려면:

// 단일 값 가져오기
String singleValue = request.getParameter("singleValue");

// 다중 값 가져오기
String[] multipleValues = request.getParameterValues("multipleValues");

이렇게 사용자가 체크박스를 여러 개 선택한 경우 getParameterValues를 사용하여 배열로 값을 가져올 수 있습니다.

쿼리 스트링(Query String)의 의미와 방식 그리고 사용하는 이유

쿼리 스트링(Query String):

쿼리 스트링은 웹 페이지의 URL 끝에 위치한 일련의 매개변수(parameter)로 구성된 문자열입니다. 일반적으로 ?으로 시작하며, 각각의 매개변수는 &로 구분됩니다. 각 매개변수는 이름과 값의 쌍으로 이루어져 있습니다. 예를 들면 다음과 같습니다:

http://www.example.com/page?name=value&age=25

위의 예시에서 ? 이후의 부분인 name=value&age=25가 쿼리 스트링입니다.

쿼리 스트링의 구성 요소:

  • 이름(name): 매개변수의 이름을 나타냅니다. 이름은 일반적으로 문자열로 지정되며, 이 이름을 통해 서버에서 클라이언트가 전송한 데이터를 식별합니다.
  • 값(value): 매개변수의 값으로 실제 전달되는 데이터를 나타냅니다. 값은 이름과 함께 해당 매개변수의 의미를 부여하고자 사용됩니다.

쿼리 스트링의 사용 방식:

  1. GET 메서드와 함께 사용: 주로 웹 폼(form)을 통해 데이터를 서버로 전송할 때 사용됩니다. 사용자가 입력한 데이터가 URL에 포함되어 GET 메서드로 서버로 전송됩니다.

  2. 동적인 콘텐츠 생성: 서버는 쿼리 스트링에 전달된 매개변수를 분석하고, 이를 기반으로 동적으로 웹 페이지의 내용을 생성할 수 있습니다.

  3. 북마크 및 공유: 특정 페이지에 대한 상태나 필터 등을 쿼리 스트링을 이용하여 URL에 포함시켜, 해당 URL을 북마크하거나 다른 사용자와 공유할 수 있습니다.

쿼리 스트링 사용의 이유:

  1. 데이터 전송: 사용자 입력 데이터 등을 서버로 전송하기 위해 사용됩니다. 특히, GET 메서드에서는 쿼리 스트링을 통해 데이터를 URL에 첨부하여 전송합니다.

  2. 동적 콘텐츠 생성: 서버에서 동적으로 웹 페이지를 생성할 때, 필요한 매개변수를 쿼리 스트링을 통해 전달하여 사용합니다.

  3. 사용자 추적 및 분석: 쿼리 스트링을 사용하여 사용자의 행동을 추적하고 분석할 수 있습니다. 특정 매개변수를 통해 사용자의 활동이나 프로모션 참여 여부 등을 파악할 수 있습니다.

  4. 북마크와 공유: 특정 상태나 필터를 URL에 포함하여 해당 페이지를 북마크하거나 다른 사용자와 공유할 수 있습니다.

쿼리 스트링은 간단하고 직접적인 방법으로 데이터를 전송하고 웹 애플리케이션에서 상태를 유지하는 데에 사용됩니다.

profile
갓벽한 개발자

0개의 댓글