/*세션 생성 및 얻기
request의 getSession()메소드는 서버에 생성된 세션이 있다면 세션을 반환하고, 없다면 새롭게 세션을 생성하여 반환합니다.
새롭게 생성된 세션인지는 HttpSession이 가지고 있는 isNew()메소드를 통해 알 수 있습니다.*/
HttpSession session = request.getSession();
HttpSession session = request.getSession(true);
//request의 getSession()메소드에 파라미터로 false를 전달하면, 이미 생성된 세션이 있다면 반환하고 없으면 null을 반환합니다.
HttpSession session = request.getSession(false);
/*세션에 값 저장
name과 value의 쌍으로 객체 Object를 저장하는 메소드입니다.
세션이 유지되는 동안 저장할 자료를 저장합니다.*/
setAttribute(String name, Object value);
session.setAttribute(이름, 값);
//세션값 조회
//반환 값은 오브젝트 유형으므로 저장된 객체로 자료 유형 변환이 필요함
String value = (String) session.getAttribute("id");
//세션 값 삭제
removeAttribute(String name); // name값에 해당하는 세션 정보를 삭제
nvalidate(); //모든 세션 정보를 삭제
project: pom.xml 파일의 최상위 루트 엘리먼트(Root Element)입니다.
modelVersion: POM model의 버전입니다.
groupId: 프로젝트를 생성하는 조직의 고유 아이디를 결정합니다. 일반적으로 도메인 이름을 거꾸로 적습니다.
artifactId: 해당 프로젝트에 의하여 생성되는 artifact의 고유 아이디를 결정합니다. Maven을 이용하여 pom.xml을 빌드할 경우 다음과 같은 규칙으로 artifact가 생성됩니다. artifactid-version.packaging. 위 예의 경우 빌드할 경우 examples-1.0-SNAPSHOT.jar 파일이 생성됩니다.
packaging: 해당 프로젝트를 어떤 형태로 packaging 할 것인지 결정합니다. jar, war, ear 등이 해당됩니다.
version: 프로젝트의 현재 버전. 추후 살펴보겠지만 프로젝트가 개발 중일 때는 SNAPSHOT을 접미사로 사용합니다. Maven의 버전 관리 기능은 라이브러리 관리를 편하게 합니다.
name: 프로젝트의 이름입니다.
url: 프로젝트 사이트가 있다면 사이트 URL을 등록하는 것이 가능합니다.
JDBC
자바 프로그램 내에서 SQL문을 실행하기 위한 자바 API(응용 프로그램에서 사용할 수 있도록, 운영 체제나 프로그래밍 언어가 제공하는 기능을 제어할 수 있게 만든 인터페이스를 뜻)
import java.sql.*;
Class.forName("com.mysql.jdbc.Driver"); //드라이버 로드
String dburl ="jdbc:mysql://localhost/dbName";
Connection con = DriverManager.getConnection ( dburl, ID, PWD ); // /커넥션 연결
Statement stmt = con.createStatement();
ResultSet rs = stmt.executeQuery("select no from user");
-Application : 웹 어플리케이션이 시작되고 종료될 때까지 변수가 유지되는 경우 사용
-Session : 웹 브라우저 별로 변수가 관리되는 경우 사용
-Request : http요청을 WAS가 받아서 웹 브라우저에게 응답할 때까지 변수가 유지되는 경우 사용
-Page : 페이지 내에서 지역변수처럼 사용
1. page :페이지 내에서 지역변수처럼 사용한다.
특정 서블릿이나 JSP가 실행되는 동안에만 정보를 유지하고 싶은 경우에 사용
PageContext 추상 클래스를 사용한다.
JSP 페이지에서 pageContext라는 내장 객체로 사용 가능 하다.
forward가 될 경우 해당 Page scope에 지정된 변수는 사용할 수 없다.
사용방법은 Application scope나 Session scope, request scope와 같다.
마치 지역변수처럼 사용된다는 것이 다른 Scope들과 다릅니다.
jsp에서 pageScope에 값을 저장한 후 해당 값을 EL표기법 등에서 사용할 때 사용됩니다.
지역 변수처럼 해당 jsp나 서블릿이 실행되는 동안에만 정보를 유지하고자 할 때 사용됩니다.
- PageComtext
PageComtext.setAttribute
PageComtext.getAttribute
2. requset
http 요청을 WAS가 받아서 웹 브라우저에게 응답할 때까지 변수값을 유지하고자 할 경우 사용한다.
HttpServletRequest 객체를 사용한다.
JSP에서는 request 내장 변수를 사용한다.
서블릿에서는 HttpServletRequest 객체를 사용한다.
값을 저장할 때는 request 객체의 setAttribute()메소드를 사용한다.
값을 읽어 들일 때는 request 객체의 getAttribute()메소드를 사용한다.
forward 시 값을 유지하고자 사용한다.
앞에서 forward에 대하여 배울 때 forward 하기 전에 request 객체의 setAttribute() 메소드로 값을 설정한 후, 서블릿이나 jsp에게 결과를 전달하여 값을 출력하도록 하였는데 이렇게 포워드 되는 동안 값이 유지되는 것이 Request scope를 이용했다고 합니다.
3.Session :
웹 브라우저별로 변수를 관리하고자 할 경우 사용한다.
웹 브라우저간의 탭 간에는 세션정보가 공유되기 때문에, 각각의 탭에서는 같은 세션정보를 사용할 수 있다.
HttpSession 인터페이스를 구현한 객체를 사용한다.
JSP에서는 session 내장 변수를 사용한다.
서블릿에서는 HttpServletRequest의 getSession()메소드를 이용하여 session 객체를 얻는다.
값을 저장할 때는 session 객체의 setAttribute()메소드를 사용한다.
값을 읽어 들일 때는 session 객체의 getAttribute()메소드를 사용한다.
장바구니처럼 사용자별로 유지가 되어야 할 정보가 있을 때 사용한다.
4. Application
웹 어플리케이션이 시작되고 종료될 때까지 변수를 사용할 수 있다.
ServletContext 인터페이스를 구현한 객체를 사용한다.
jsp에서는 application 내장 객체를 이용한다.
서블릿의 경우는 getServletContext()메소드를 이용하여 application객체를 이용한다.
웹 어플리케이션 하나당 하나의 application객체가 사용된다.
값을 저장할 때는 application객체의 setAttribute()메소드를 사용한다.
값을 읽어 들일 때는 application객체의 getAttribute()메소드를 사용한다.