[JSP] 10.세션(Session)

2020. 9. 15. 13:05·💻 Dev/JSP & Servlet
세션(Session)이란?

 

 

 

http 프로토콜은 클라이언트와 서버 간에 요청, 응답이 한 번 이루어지면 연결을 해제한다.

 

세션이란 쿠키와 마찬가지로 서버와 클라이언트의 관계를 유지시켜주는 방법 중의 하나이다.

하지만 쿠키는 브라우저(클라이언트)에서 생성,저장되고 세션은 웹 컨테이너(서버)에 저장, 생성된다.
쿠키는 보안이 취약한 단점이 있어서 요즘 추세는 세션을 선호한다.

예제

login.jsp

 <body>
	<form action="loginCon" method="post">
		ID : <input type="text" name="mID"><br>
		PW : <input type="password" name="mPW"><br>
		<input type="submit" value="login">
	</form>
</body>

 

세션 테스트를 위해 간단한 form을 logn.jsp에 작성한다.

그리고 데이터를 받기 위해 loginCon 서블릿을 만들자.

 

 LoginCon.java

@WebServlet("/loginCon")
public class LoginCon extends HttpServlet {
	protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
		PrintWriter out = response.getWriter();
        
		//id,pw데이터 담아 출력해보기
		String mId = request.getParameter("mID");
		String mPw = request.getParameter("mPW");
		out.print("mId : " + mId);
		out.print("mPw : " + mPw);
		
		//세션 생성하고 세션객체에 저장
		HttpSession session = request.getSession();
		session.setAttribute("memberId", mId);
		
        //세션 저장 후 loginOk.jsp로 응답
		response.sendRedirect("loginOk.jsp");
	}
	protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
		doGet(request, response);
	}
}

 

세션 저장 후 loginOk.jsp로 응답해준다.

(doGet에 코드를 작성하는 이유는 어차피 doPost에서 doGet메소드를 호출하기 때문)

  • HttpSession session = request.getSession(); - 세션 생성 및 얻기
  • session.setAttribute(이름,값); - 세션에 memberId라는 이름의 세션 값 저장

loginOk.jsp

    <body>
		<%
			session = request.getSession();	
			out.print("memberId : " + session.getAttribute("memberId") + "<br>");
		%>
		
		<form action="logoutCon" method="post">
			<input type="submit" value="logout">
		</form>
    </body>
  • request.getSession() - 세션 얻기
  • session.getAttribute("세션이름"); - 세션 값 조회

request.getSession() 메소드로 서버에 생성된 세션이 있다면 세션을 얻고 memberId이름을 가진 세션 값을 조회해본다.

그리고 세션을 날려주기 위해 LogoutCon이라는 서블릿으로 이동시키자.

 

 

form에 id, pw를 입력하고 login을 누르면

 

 

user라는 세션 값을 조회할 수 있다.

 

LogoutCon.java

@WebServlet("/logoutCon")
public class LogoutCon extends HttpServlet {
	protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
		
		//세션 담아와서
		HttpSession session = request.getSession();
		//세션 날리기
		session.invalidate();
		//login페이지로 이동시키기
		response.sendRedirect("login.jsp");
	}

로그아웃하면 서버에 세션이 필요 없고 있어서도 안된다. 
session.invalidate();로 세션을 날린다.

 

loginOk.jsp에서 logout버튼을 누르면 세션이 종료되고 login.jsp로 바로 이동한다.

 

* 이때, login창에서 세션 값이 있는지 확인하여 있으면 로그인이 아니라 바로 loginOk.jsp를 띄워줘야 한다.

 

login.jsp

 <body>
		<%
        	//이부분 추가
			if(session.getAttribute("memberId") != null)
				response.sendRedirect("loginOk.jsp");
		%>
        
		<form action="loginCon" method="post">
			ID : <input type="text" name="mID"><br>
			PW : <input type="password" name="mPW"><br>
			<input type="submit" value="login">
		</form>
    </body>

 

 

 

[참고] 인프런 - 백기선 님의 실전 JSP - 신입 프로그래머를 위한 강좌를 보고 공부한 내용을 바탕으로 작성했습니다.

저작자표시 비영리 (새창열림)

'💻 Dev > JSP & Servlet' 카테고리의 다른 글

JSP 파일이 브라우저 화면에 출력되기까지의 과정은?  (0) 2025.01.09
[JSP] 게시판 미니 프로젝트 - MVC2패턴 적용  (0) 2020.10.26
[JSP] 11.JDBC(Java Database Connectivity)  (0) 2020.09.16
[JSP] 9.쿠키(Cookie)  (0) 2020.09.10
[JSP] 8.jsp request,response  (0) 2020.09.01
[JSP] 7.form 데이터 처리  (0) 2020.08.31
'💻 Dev/JSP & Servlet' 카테고리의 다른 글
  • [JSP] 게시판 미니 프로젝트 - MVC2패턴 적용
  • [JSP] 11.JDBC(Java Database Connectivity)
  • [JSP] 9.쿠키(Cookie)
  • [JSP] 8.jsp request,response
현주먹
현주먹
대구 불주먹 출신 현주먹의 개발.log
  • 현주먹
    현주먹의 개발로그
    현주먹
  • 전체
    오늘
    어제
    • 전체글 (167)
      • 👶🏻 CS (15)
        • Operating System (8)
        • Database (4)
        • Data Structure (2)
        • Software Engineering (1)
      • 💻 Dev (54)
        • Java & OOP (24)
        • Spring (4)
        • JPA (5)
        • Test Code (1)
        • Database (1)
        • JSP & Servlet (13)
        • Etc (6)
      • 💡 Algorithm (25)
        • 인프런 (9)
        • 백준 (16)
      • 🛠 DevOps & Tool (11)
        • Linux (4)
        • AWS (1)
        • Git (2)
        • Etc (4)
      • 📝 끄적끄적 (62)
        • 후기 및 회고 (5)
        • TDD, 클린 코드 with Java 17기 (3)
        • F-Lab (23)
        • 🖥️ 자바의 정석 (11)
        • 📖 Clean Code (3)
        • 항해99 코테 스터디 (11)
        • 📖 가상 면접 사례로 배우는 대규모 시스템 설계 .. (5)
  • 블로그 메뉴

    • 🐈‍⬛ GitHub
    • TIL repository
  • 인기 글

  • 최근 글

  • 최근 댓글

  • 태그

    til
    에프랩
    자바의신절판
    PostGreSQL함수
    F-Lab
    백준
    개발자취업
    f-lab 후기
    항해99
    TDD 클린 코드 with Java
    jsp
    C
    자바의정석
    로또 미션
    오블완
    인프런 특정문자뒤집기
    오라클
    99클럽
    백준10250
    코테스터디
    에프랩 후기
    JPA
    객체지향
    NextSTEP
    인프런 단어뒤집기
    코딩테스트준비
    티스토리챌린지
    ==와 equals()
    데브클럽
    개발자멘토링
  • hELLO· Designed By정상우.v4.10.2
현주먹
[JSP] 10.세션(Session)
상단으로

티스토리툴바