반응형
JSP 액션, 선언, 스크립트릿

1. JSP 액션

액션(Action)은 주요 구성 요소 중 하나로, 세가지 기능을 지원
- JSp 페이지 간 흐름 제어
- 자바 애플릿 지원
- 자바 빈즈 컴포넌트와 JSP 상호작용 지원

2. include 액션

include 액션은 다른 파일을 불러온다는 면에서 include 지시어와 개념이 흡사.
lnclude 지시어는 해당 파일을 포함 시킨 다음 컴파일 하는데 비해 include 액션은
실행 시점에서 해당 파일을 호출하여 그 결과를 포함한다는데 차이점.

include 지시어와 마찬가지로 include 액션은 유용한 기능을 제공하지만, 페이지
변경 사항이 있을때마다 매번 컴파일하여 성능저하의 단점이 있다.

include 액션 : 파일두개 컴파일 따로 관리하므로 동적인 페이지 포함시 사용
include 지시어 : 파일두개 컴파일 하나로 하므로 정적인 페이지 포함시 사용

<jsp:include page="filename.jsp" />

include액션 특징중 하나가 변수를 전달할 수 있다는 점.
param태그를 이용해 속성값을 전달 할수 있다.
<jsp:param name="tel" value="080-700-4945" />

전달된 값은 request.getParameter() 메서드를 통해 접근 가능.
<%= request.getParameter("tel") %>

include 지시어와는 달리 page 지시어가 와도 아무런 문제없이 실행이 가능하다.

3. forward 액션

forward 액션은 include 액션과 유사하지만 현재 페이지를 완전히 다른 페이지로 전환
할 때 사용한다.
 - include 액션은 제어권을 다른jsp로 넘겼다가 가져오지만
 - forward 액션은 제어권을 완전히 넘겨 버린다.

<jsp:forward page="forwardingfilename.jsp" />

forward도 include 액션 과 동일하게 param으로 인자 전달이 가능하다.

4. plugin 액션

plugin 액션은 웹 브라우저에서 자바 플러그인을 사용하여 자바 애플릿이나 빈즈
컴포넌트를 실행 할 수 있게 한다.
plugin 액션은 웹 브라우저 에 따라 자동으로 해당 태그를 생성한다.

5. useBean 액션

액션에서 가장 중요한 부분이다.
<jsp:useBean id="objectname" class="beansClassname" />
<jsp:getProperty name="objectname" class="attributename" />
<jsp:setProperty name="objectname" class="attributename" />

useBean 태그는 빈즈 사용한다는 선언 태그.
getProperty는 빈즈에서 값을 가져올때 사용하는 태그
setProperty는 JSP에서 빈즈 값을 설정 할 때 사용하는 태그

name과 class의 속성은 빈즈클래스의 인스턴스 이름으로 id값에 설정한
변수이름과, class의 메서드 매칭될 속성값을 뜻한다.

4. 선언

JSP 내에에서 메서드나 멤버 변수를 선언할 때 사용한다.
<%! ... %>

선언태그는 <%! %> 사이에 기술하는데 '!(느낌표)'가 빠지면 스크립트가
되므로 각 별히 주의할 필요가 있다.

5. 표현식

표현식(Expression)은 <%= %> 를 사용해서 간단한 데이터 출력이나,
메서드 호출에 사용한다. 코드마지막에 ';(세미콜론)' 을 사용하지 않는다.

out.println()으로 변환되는 것과 마찬가지 이다. 산술식과 + "문자열" 형태도
가능하다.

메서드 호출 : <%= ez2dj() %>
변수 출력 : <%= oblivion %>
사칙 연산, 문자 결합 : <%= "i+2="+(i+2)+"스크립트 릿" %>

6. 스크립트릿

스크립트릿(Scriptlet)은 JSP 문서 내에 자바 코드를 기술 하는 부분.
본문 어디에서도 자유롭게 사용 가능.

<% %> 로 스크립트릿 표현. 순수 자바 코드만 사용 가능.
HTML이 출력 필요부분시 out.println()을 이용, 또는 스크립트릿 중지 이후
다시 스크립트릿 활성화 하는 캐노가다 방법 적용.


반응형

+ Recent posts