2 v 4 2 JSP page content Type

  • Slides: 51
Download presentation

2. 쿠키 기술의 사용 방법 v 쿠키 데이터를 읽는 방법 – 조회 기능 [예제

2. 쿠키 기술의 사용 방법 v 쿠키 데이터를 읽는 방법 – 조회 기능 [예제 4 -2] 쿠키 데이터를 읽는 JSP 페이지 <%@page content. Type= “text/html; charset=euc-kr ”%> <% Cookie[] cookies = request. get. Cookies(); %> <HTML> <HEAD><TITLE>쿠키 데이터 읽기</TITLE></HEAD> <BODY> 이름: <%= get. Cookie. Value(cookies, “NAME ”) %> <BR> 성별: <%= get. Cookie. Value(cookies, “GENDER ”) %> <BR> 나이: <%= get. Cookie. Value(cookies, “AGE ”) %> </BODY> </HTML> <%! private String get. Cookie. Value(Cookie[] cookies, String name) { String value = null; if (cookies == null) return null; for (Cookie cookie : cookies) { if (cookie. get. Name(). equals(name)) return cookie. get. Value(); } return null; } %>> 10/50

2. 쿠키 기술의 사용 방법 v 쿠키가 특정 경로명을 갖는 URL로만 전송되도록 만드는 방법

2. 쿠키 기술의 사용 방법 v 쿠키가 특정 경로명을 갖는 URL로만 전송되도록 만드는 방법 [예제 4 -5] URL 경로명을 지정한 쿠키를 저장하는 JSP 페이지 <%@page content. Type= “text/html; charset=euc-kr ”%> <% Cookie cookie = new Cookie( “JOB ”, ”programmer ”); cookie. set. Path( “/brain 04/sub 1/ ”); response. add. Cookie(cookie); %> <HTML> <HEAD><TITLE>쿠키 데이터 저장하기</TITLE></HEAD> <BODY> JOB 쿠키가 저장되었습니다. <BR> </BODY> </HTML> 18/50

2. 쿠키 기술의 사용 방법 v 쿠키가 특정 경로명을 갖는 URL로만 전송되도록 만드는 방법

2. 쿠키 기술의 사용 방법 v 쿠키가 특정 경로명을 갖는 URL로만 전송되도록 만드는 방법 [예제 4 -6] JOB 쿠키의 값을 출력하는 JSP 페이지 <%@page content. Type= “text/html; charset=euc-kr ”%> <% Cookie[] cookies = request. get. Cookies(); %> <HTML> <HEAD><TITLE>쿠키 데이터 읽기</TITLE></HEAD> <BODY> JOB: <%= get. Cookie. Value(cookies, “JOB ”) %> <BR> </BODY> </HTML> <%! private String get. Cookie. Value(Cookie[] cookies, String name) { String value = null; if (cookies == null) return null; for (Cookie cookie : cookies) { if (cookie. get. Name(). equals(name)) return cookie. get. Value(); } return null; } %> 19/50

2. 쿠키 기술의 사용 방법 v 쿠키가 여러 웹 서버로 전송되도록 만드는 방법 [예제

2. 쿠키 기술의 사용 방법 v 쿠키가 여러 웹 서버로 전송되도록 만드는 방법 [예제 4 -8] LOGIN_ID 쿠키의 값을 출력하는 JSP 페이지 <%@page content. Type= “text/html; charset=euc-kr ”%> <% Cookie[] cookies = request. get. Cookies(); %> <HTML> <HEAD><TITLE>쿠키 데이터 읽기</TITLE></HEAD> <BODY> LOGIN_ID: <%= get. Cookie. Value(cookies, “LOGIN_ID ”) %> </BODY> </HTML> <%! private String get. Cookie. Value(Cookie[] cookies, String name) { String value = null; if (cookies == null) return null; for (Cookie cookie : cookies) { if (cookie. get. Name(). equals(name)) return cookie. get. Value(); } return null; } %> 23/50

3. 세션 기술의 사용 방법 v 서블릿 클래스에서 세션 기술을 사용하는 방법 http: //localhost:

3. 세션 기술의 사용 방법 v 서블릿 클래스에서 세션 기술을 사용하는 방법 http: //localhost: 8080/brain 04/ptest/Food. html HTML 문 서 [그림 4 -17]의 첫 번째 화면의 URL http: //localhost: 8080/brain 04/ptest/animal 서블릿 클 래스 [그림 4 -17]의 두 번째 화면의 URL http: //localhost: 8080/brain 04/ptest/result [그림 4 -17]의 세 번째 화면의 URL 30/50

3. 세션 기술의 사용 방법 v 서블릿 클래스에서 세션 기술을 사용하는 방법 [예제 4

3. 세션 기술의 사용 방법 v 서블릿 클래스에서 세션 기술을 사용하는 방법 [예제 4 -10] 성격 테스트의 두 번째 화면을 출력하는 서블릿 클래스 import javax. servlet. *; import javax. servlet. http. *; import java. io. *; public class Animal. Servlet extends Http. Servlet { public void do. Get(Http. Servlet. Request request, Http. Servlet. Response response) throws IOException, Servlet. Exception { String food = request. get. Parameter( “FOOD ”); Http. Session session = request. get. Session(); session. set. Attribute( “FOOD ”, food); response. set. Content. Type( “text/html; charset=euc-kr ”); Print. Writer out = response. get. Writer(); out. println( “<HTML> ”); out. println( “<HEAD><TITLE>성격 테스트</TITLE></HEAD> ”); out. println( “<BODY> ”); out. println( “<H 3>좋아하는 동물은? </H 3> ”); out. println( “<FORM ACTION=result> ”); out. println( “<INPUT TYPE=TEXTFIELD NAME=ANIMAL> ”); out. println( “<INPUT TYPE=SUBMIT VALUE= ’확인 ’> ”); out. println( “</FORM> ”); out. println( “</BODY> ”); out. println( “</HTML> ”); } } 32/50

3. 세션 기술의 사용 방법 v 서블릿 클래스에서 세션 기술을 사용하는 방법 [예제 4

3. 세션 기술의 사용 방법 v 서블릿 클래스에서 세션 기술을 사용하는 방법 [예제 4 -11] 성격 테스트의 결과를 출력하는 서블릿 클래스 import javax. servlet. *; import javax. servlet. http. *; import java. io. *; public class Result. Servlet extends Http. Servlet { public void do. Get(Http. Servlet. Request request, Http. Servlet. Response response) throws IOException, Servlet. Exception { Http. Session session = request. get. Session(); String food = (String) session. get. Attribute( “FOOD ”); String animal = request. get. Parameter( “ANIMAL ”); session. invalidate(); response. set. Content. Type( “text/html; charset=euc-kr ”); Print. Writer out = response. get. Writer(); out. println( “<HEAD><TITLE>성격 테스트</TITLE></HEAD> ”); out. println( “<BODY> ”); out. println( “<H 3>성격 테스트</H 3> ”); out. printf( “당신은 %s와 %s를 좋아하는 성격입니다. ”, food, animal); out. println( “</BODY> ”); out. println( “</HTML> ”); } } 33/50

3. 세션 기술의 사용 방법 v JSP 페이지에서 세션 기술을 사용하는 방법 http: //localhost:

3. 세션 기술의 사용 방법 v JSP 페이지에서 세션 기술을 사용하는 방법 http: //localhost: 8080/brain 04/subscribe/Personal. Info. html [그림 4 -20]의 첫 번째 화면의 URL http: //localhost: 8080/brain 04/subscribe/Agreement. jsp [그림 4 -20]의 두 번째 화면의 URL http: //localhost: 8080/brain 04/subscribe/Subscribe. jsp 회원 정보를 저장하는 JSP 페이지의 URL http: //localhost: 8080/brain 04/subscribe/Result. jsp 회원 가입 결과를 출력하는 JSP 페이지의 URL 38/50

3. 세션 기술의 사용 방법 v JSP 페이지에서 세션 기술을 사용하는 방법 § 앞

3. 세션 기술의 사용 방법 v JSP 페이지에서 세션 기술을 사용하는 방법 § 앞 페이지의 네 URL에 해당하는 HTML 문서와 JSP 페이지는 다음과 같이 작성하면 된 다. [예제 4 -12] 개인 정보 입력 화면을 제공하는 HTML 문서 <HTML> <HEAD> <META http-equiv= “Content-Type ” content= ”text/html; charset=euc-kr ”> <TITLE>회원 가입</TITLE> </HEAD> <BODY> 개인 정보를 입력하세요. <FORM ACTION=Agreement. jsp METHOD=POST> 아이디: <INPUT TYPE=TEXT NAME=ID><BR> 패스워드: <INPUT TYPE=PASSWORD NAME=PASSWORD><BR> 이름: <INPUT TYPE=TEXT NAME=NAME><BR> <INPUT TYPE=SUBMIT VALUE= ‘확인 ’> </FORM> </BODY> </HTML> 39/50

3. 세션 기술의 사용 방법 v JSP 페이지에서 세션 기술을 사용하는 방법 [예제 4

3. 세션 기술의 사용 방법 v JSP 페이지에서 세션 기술을 사용하는 방법 [예제 4 -13] 약관 동의 화면을 제공하는 JSP 페이지 <%@page content. Type= “text/html; charset=euc-kr ”%> <% request. set. Character. Encoding( “euc-kr ”); String id = request. get. Parameter( “ID ”); String password = request. get. Parameter( “PASSWORD ”); String name = request. get. Parameter( “NAME ”); session. set. Attribute( “ID ”, id); session. set. Attribute( “PASSWORD ”, password); session. set. Attribute( “NAME ”, name); %> 세션 데이터를 저장합니 <HTML> 다 <HEAD><TITLE>회원 가입</TITLE></HEAD> <BODY> <H 3>약관</H 3> --------------------------- <BR> 1. 회원 정보는 웹 사이트의 운영을 위해서만 사용됩니다. <BR> 2. 웹 사이트의 정상 운영을 방해하는 회원은 탈퇴 처리합니다. <BR> --------------------------- <BR> <FORM ACTION=Subscribe. jsp METHOD=POST> 위의 약관에 동의하십니까? <INPUT TYPE=RADIO NAME=AGREE VALUE=YES> 동의함 <INPUT TYPE=RADIO NAME=AGREE VALUE=NO> 동의하지 않음 <BR> <INPUT TYPE=SUBMIT VALUE= ‘확인 ’> </FORM> </BODY> </HTML> 40/50

3. 세션 기술의 사용 방법 v JSP 페이지에서 세션 기술을 사용하는 방법 [예제 4

3. 세션 기술의 사용 방법 v JSP 페이지에서 세션 기술을 사용하는 방법 [예제 4 -14] 회원 정보를 저장하는 JSP 페이지 <%@page content. Type= “text/html; charset=euc-kr ”%> <%@page import=“java. io. *”%> <% String agree = request. get. Parameter( “AGREE ”); String result = null; if (agree. equals( “YES ”)) { String id = (String) session. get. Attribute( “ID ”); String password = (String) session. get. Attribute( “PASSWORD ”); String name = (String) session. get. Attribute( “NAME ”); Print. Writer writer = null; try { String file. Path = application. get. Real. Path( ”/WEB-INF/ ” + id + “. txt ”); writer = new Print. Writer(file. Path); writer. println( “아이디: ” + id); writer. println( “패스워드: ” + password); writer. println( “이름: ” + name); result = “SUCCESS ”; } catch (IOException ioe) { result = “FAIL ”; } [예제 4 -14] 회원 정보를 저장하는 JSP 페이지 finally { try { writer. close(); } catch (Exception e) { } } } else { result = “FAIL ”; } session. invalidate(); response. send. Redirect( “Result. jsp? RESULT= ” + result); %> 41/50

3. 세션 기술의 사용 방법 v JSP 페이지에서 세션 기술을 사용하는 방법 [예제 4

3. 세션 기술의 사용 방법 v JSP 페이지에서 세션 기술을 사용하는 방법 [예제 4 -15] 회원 가입 결과를 출력하는 JSP 페이지 <%@page content. Type= “text/html; charset=euc-kr ”%> <% String result = request. get. Parameter( “RESULT ”); %> <HTML> <HEAD><TITLE>회원 가입</TITLE></HEAD> <BODY> <H 3>회원 가입 결과</H 3> <% if (result. equals( “SUCCESS ”)) out. println( “가입되었습니다. ”); else out. println( “가입되지 않았습니다. ”); %> </BODY> </HTML> 42/50

3. 세션 기술의 사용 방법 v URL 재작성 메커니즘의 사용 방법 [예제 4 -17]

3. 세션 기술의 사용 방법 v URL 재작성 메커니즘의 사용 방법 [예제 4 -17] 세션 데이터를 읽는 JSP 페이지 <%@page content. Type= “text/html; charset=euc-kr ”%> <HTML> <HEAD><TITLE>세션 데이터를 읽는 JSP 페이지</TITLE></HEAD> <BODY> 이름: <%= session. get. Attribute( “NAME ”) %> <BR> 나이: <%= session. get. Attribute( “AGE ”) %> <BR> 성별: <%= session. get. Attribute( “GENDER ”) %> </BODY> </HTML> § 이 두 예제를 brain 04 웹 애플리케이션 디렉터리에 Write. Session. Data. jsp와 Read. Session. Data. jsp이름으로 저장한다. 48/50