로그아웃
세션에 저장되어 있는 loginMember를 없애주기만 하면 됨
<a href="/community/member/logout" id="logout-btn">로그아웃</a>
package edu.kh.community.member.controller;
import java.io.IOException;
import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession;
@WebServlet("/member/logout")
public class LogoutServlet extends HttpServlet {
// a태그를 이용한 요청은 무조건 GET 방식
@Override
protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
// *** 로그아웃 ***
// Session Scope에 세팅된 회원 정보를 없앰
// 1) Session에서 회원 정보만 없앰
// Session 얻어오기
HttpSession session = req.getSession();
// 1) Session에서 회원 정보만 없앰
// session.removeAttribute("loginMember");
// 2) Session 전체를 없애고 새로운 Session 만들기 (더 많이 사용되는 방법)
session.invalidate(); // 세션 무효화
// 현재 세션을 없앰 -> 자동으로 새로운 세션 생성됨
// 메인 페이지로 돌아가기
// 1) forward : 로그아웃 응답 화면을 만든다(부적절)
// 2) Redirect : 메인 페이지 재요청
// 메인페이지 == 최상위주소(/community)로 요청했을 때 화면
resp.sendRedirect(req.getContextPath());
}
}