쿠키 예제

@Controller
public class GuestbookController {
    @Autowired
    GuestbookService guestbookService;

      @GetMapping(path="/list")
    public String list(@RequestParam(name="start", required=false, defaultValue="0") int start,
                       ModelMap model, @CookieValue(value="count", defaultValue="1", required=true) String value,
                       HttpServletResponse response) {

        // 쿠키 값을 1증가 시킨다.
        try {
            int i = Integer.parseInt(value);
            value = Integer.toString(++i);
        }catch(Exception ex){
            value = "1";
        }

        // 쿠키를 전송한다.
        Cookie cookie = new Cookie("count", value);
        cookie.setMaxAge(60 * 60 * 24 * 365); // 1년 동안 유지.
        cookie.setPath("/"); // / 경로 이하에 모두 쿠키 적용. 
        response.addCookie(cookie);

        List<Guestbook> list = guestbookService.getGuestbooks(start);

        int count = guestbookService.getCount();
        int pageCount = count / GuestbookService.LIMIT;
        if(count % GuestbookService.LIMIT > 0)
            pageCount++;

        List<Integer> pageStartList = new ArrayList<>();
        for(int i = 0; i < pageCount; i++) {
            pageStartList.add(i * GuestbookService.LIMIT);
        }

        model.addAttribute("list", list);
        model.addAttribute("count", count);
        model.addAttribute("pageStartList", pageStartList);
        model.addAttribute("cookieCount", value); // 쿠키를 추가한다.

        return "list";
    }

    @PostMapping(path="/write")
    public String write(@ModelAttribute Guestbook guestbook,
                        HttpServletRequest request) {
        String clientIp = request.getRemoteAddr();
        System.out.println("clientIp : " + clientIp);
        guestbookService.addGuestbook(guestbook, clientIp);
        return "redirect:list";
    }
}

세션 예제

@Controller
public class GuessNumberController {

    @GetMapping("/guess")
    public String guess(@RequestParam(name="number", required=false) Integer number,
            HttpSession session,
            ModelMap model) {

        String message = null;

        // get방식으로 /guess 를 요청하는데 파라미터 number가 없을 경우에는 session에 count를 0으로 randomNumber엔 1부터 100사이의 값을 저장합니다.
        if(number == null) {
            session.setAttribute("count", 0);
            session.setAttribute("randomNumber", (int)(Math.random() * 100) + 1); // 1 ~ 100사이의 random값
            message = "내가 생각한 숫자를 맞춰보세요.";
        }else {

            // number파라미터가 있을 경우 세션에서 값을 읽어들인 후, number와 세션에 저장된 값을 비교합니다.
            // 값을 비교해서 작거나 크다면 카운트를 1증가시켜주고
            // 값이 같다면 세션 정보를 삭제합니다.
            // 각 상황에 맞는 메시지를 message변수에 저장을 한 후 jsp에게 전달하기 위해서 ModelMap의 addAttribute메소드를 통해 전달하게 됩니다.
            int count = (Integer)session.getAttribute("count");
            int randomNumber = (Integer)session.getAttribute("randomNumber");


            if(number < randomNumber) {
                message = "입력한 값은 내가 생각하고 있는 숫자보다 작습니다.";
                session.setAttribute("count", ++count);
            }else if(number > randomNumber) {
                message = "입력한 값은 내가 생각하고 있는 숫자보다 큽니다.";
                session.setAttribute("count", ++count);
            }else {
                message = "OK " + ++count + " 번째 맞췄습니다. 내가 생각한 숫자는 " + number + " 입니다.";
                session.removeAttribute("count");
                session.removeAttribute("randomNumber");
            }
        }

        model.addAttribute("message", message);

        return "guess";
    }
}
<%@ page language="java" contentType="text/html; charset=UTF-8"
    pageEncoding="UTF-8"%>
<%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>       
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>숫자 맞추기 게임</title>
</head>
<body>
<h1> 숫자 맞추기 게임.</h1>
<hr>
<h3>${message }</h3>

<c:if test="${sessionScope.count != null}">
<form method="get" action="guess">
1부터 100사이의 숫자로 맞춰주세요.<br>
<input type="text" name="number"><br>
<input type="submit" value="확인">
</form>
</c:if>

<a href="guess">게임 다시 시작하기.</a>
</body>
</html>

세션 예제2

@Controller
public class GuestbookAdminController {

       @GetMapping(path="/loginform")
        public String loginform() {
            return "loginform";
        }

        @PostMapping(path="/login")
        public String login(@RequestParam(name="passwd", required=true) String passwd, 
                HttpSession session,
                RedirectAttributes redirectAttr) {

            if("1234".equals(passwd)) {
                session.setAttribute("isAdmin", "true");
            }else {
                redirectAttr.addFlashAttribute("errorMessage","암호가 틀렸습니다.");
                return "redirect:/loginform";
            }
            return "redirect:/list";
        }

       @GetMapping(path="/logout")
        public String login(HttpSession session) {
            session.removeAttribute("isAdmin");
            return "redirect:/list";
        }

}
<%@ page language="java" contentType="text/html; charset=UTF-8"
    pageEncoding="UTF-8"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>loginform</title>
</head>
<body>
<h1>관리자 로그인</h1>
<br><br>
${errorMessage}<br>

<form method="post" action="login">
    암호 : <input type="password" name="passwd"><br>
    <input type="submit">
</form>

</body>
</html>
@Controller
public class GuestbookController {
    @Autowired
    GuestbookService guestbookService;

    @GetMapping(path="/list")
    public String list(@RequestParam(name="start", required=false, defaultValue="0") int start,
                       ModelMap model, @CookieValue(value="count", defaultValue="1", required=true) String value,
                       HttpServletResponse response) {

        try {
            int i = Integer.parseInt(value);
            value = Integer.toString(++i);
        }catch(Exception ex){
            value = "1";
        }

        Cookie cookie = new Cookie("count", value);
        cookie.setMaxAge(60 * 60 * 24 * 365); // 1년 동안 유지.
        cookie.setPath("/"); // / 경로 이하에 모두 쿠키 적용. 
        response.addCookie(cookie);

        List<Guestbook> list = guestbookService.getGuestbooks(start);

        int count = guestbookService.getCount();
        int pageCount = count / GuestbookService.LIMIT;
        if(count % GuestbookService.LIMIT > 0)
            pageCount++;

        List<Integer> pageStartList = new ArrayList<>();
        for(int i = 0; i < pageCount; i++) {
            pageStartList.add(i * GuestbookService.LIMIT);
        }

        model.addAttribute("list", list);
        model.addAttribute("count", count);
        model.addAttribute("pageStartList", pageStartList);
        model.addAttribute("cookieCount", value);

        return "list";
    }

    @PostMapping(path="/write")
    public String write(@ModelAttribute Guestbook guestbook,
                        HttpServletRequest request) {
        String clientIp = request.getRemoteAddr();
        System.out.println("clientIp : " + clientIp);
        guestbookService.addGuestbook(guestbook, clientIp);
        return "redirect:list";
    }


    @GetMapping(path="/delete")
    public String delete(@RequestParam(name="id", required=true) Long id, 
                         @SessionAttribute("isAdmin") String isAdmin,
                         HttpServletRequest request,
                         RedirectAttributes redirectAttr) {
        if(isAdmin == null || !"true".equals(isAdmin)) { // 세션값이 true가 아닐 경우
            redirectAttr.addFlashAttribute("errorMessage", "로그인을 하지 않았습니다.");
            return "redirect:loginform";
        }
        String clientIp = request.getRemoteAddr();
        guestbookService.deleteGuestbook(id, clientIp);
        return "redirect:list";        
    }
}
<%@ page language="java" contentType="text/html; charset=UTF-8"
    pageEncoding="UTF-8"%>
<%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>    
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>방명록 목록</title>
</head>
<body>

<h1>방명록</h1>
<br>
방명록 전체 수 : ${count }, 방문한 수 : ${cookieCount }<br><br>


<c:forEach items="${list}" var="guestbook">

${guestbook.id }<br>
${guestbook.name }<br>
${guestbook.content }<br>
${guestbook.regdate }<br>
<c:if test="${sessionScope.isAdmin == 'true'}"><a href="delete?id=${guestbook.id}">삭제</a><br><br></c:if>
</c:forEach>
<br>

<c:forEach items="${pageStartList}" var="pageIndex" varStatus="status">
<a href="list?start=${pageIndex}">${status.index +1 }</a>&nbsp; &nbsp;
</c:forEach>

<br><br>
<form method="post" action="write">
name : <input type="text" name="name"><br>
<textarea name="content" cols="60" rows="6"></textarea><br>
<input type="submit" value="등록">
</form>
</body>
</html>

출처: 부스트코스 웹 프로그래밍 (https://www.edwith.org/boostcourse-web)

+ 따끈한 최근 게시물