SessionとCookieの単純なインスタンスについて


SessionとCookieについてはここで詳しくは言いませんが、直接コード説明サイトの「私を覚えて」checkboxのアプリにアクセスします
最初のサーブレット
public class cookieServlet extends HttpServlet {

	
	 
	public void doGet(HttpServletRequest request, HttpServletResponse response)
			throws ServletException, IOException {
		response.setContentType("text/html;charset=UTF-8");
		request.setCharacterEncoding("UTF-8");
		PrintWriter out = response.getWriter();
		String name = (String) request.getSession().getAttribute("userName");
		if(name!=null&&!name.trim().equals("")){
			out.print(" "+name);
		}else{
			out.print(" ");
		}
		System.out.println(request.getSession().getId()+"------get ");
		
	}

	
	public void doPost(HttpServletRequest request, HttpServletResponse response)
			throws ServletException, IOException {
		response.setContentType("text/html;charset=UTF-8");
		PrintWriter out = response.getWriter();
		String checked = request.getParameter("me");
		if(checked!=null){
			Cookie ck = new Cookie("JSESSIONID",request.getSession().getId())
			ck.setMaxAge(60*30);
			ck.setPath("/");
			response.addCookie(ck);
		}
		String userName = request.getParameter("userName");
		if(userName!=null&&!userName.trim().equals("")){
			request.getSession().setAttribute("userName", userName);
		}
		//doGet(request, response);
		// cookie url 
		//form       dopost session doget session                   
		//response.sendRedirect(request.getContextPath()+"/cookieServlet");
		System.out.println(request.getSession().getId()+"------post ");
		//url  
		String url = response.encodeRedirectURL(request.getContextPath()+"/cookie                Servlet");
		response.sendRedirect(url);
	}

}

2番目のサーブレット
package com.test.cookie;

import java.io.IOException;
import java.io.PrintWriter;

import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

public class TestCookieServlet extends HttpServlet {

	
	public void doGet(HttpServletRequest request, HttpServletResponse response)
			throws ServletException, IOException {

		response.setContentType("text/html;charset=UTF-8");
		PrintWriter out = response.getWriter();
		String name = (String) request.getSession().getAttribute("userName");
		if(name!=null&&!name.trim().equals("")){
			out.print(" "+name+"-----TestCookieServlet");
		}else{
			out.print(" -----TestCookieServlet");
		}
	}

	
	public void doPost(HttpServletRequest request, HttpServletResponse response)
			throws ServletException, IOException {

		response.setContentType("text/html");
		PrintWriter out = response.getWriter();
		
	}

}

jspページ
<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>
<%
String path = request.getContextPath();
String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/";
%>

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
  <head>
    <base href="<%=basePath%>">
    
    <title>My JSP 'index.jsp' starting page</title>
	<meta http-equiv="pragma" content="no-cache">
	<meta http-equiv="cache-control" content="no-cache">
	<meta http-equiv="expires" content="0">    
	<meta http-equiv="keywords" content="keyword1,keyword2,keyword3">
	<meta http-equiv="description" content="This is my page">
	<!--
	<link rel="stylesheet" type="text/css" href="styles.css">
	-->
  </head>
  
  <body>
    
   	<!-- <form action="cookieServlet" method="post"> -->
   	<!--url   -->
   	<form action="<%=response.encodeURL("cookieServlet")%>" method="post">
   		<input type="text" name="userName"><br/>
   		<input type="checkbox" name="me" value="1"> 
   		<input type="submit">
   	</form>
   	<br/>
   	<!-- <a href="cookieServlet"/>GOGO</a> -->
   	<!-- url   -->
   	<a href="<%=response.encodeURL("cookieServlet")%>">GOGO</a>
  </body>
</html>

説明
1通常ブラウザクッキーはオンですが、万が一無効になったらurl書き換えで解決します.もちろん他の方法もあります.
2人でテストするとき(火狐)はクッキーを無効にしても正常にアクセスできますが、firebugで発見した場合、クッキーオプションでlocalhostのクッキーを無効にすればいいのです.
3ここでクッキーの構成についてはapiでいいので説明がはっきりしています.