J2EE中Servlet操作cookie
一、基本概念
cookie是web服務器通過瀏覽器保存在www用戶端硬盤上的一個文本文件,這個文件中包含了文本信息文本信息的內容是以“名/值”對的形式進行儲存。可以讓web開發者通過程序讀寫這個文本文件在Windows XP中保存Cookie的目錄是:C:\Documents and Settings\用戶名\Cookies。
Cookie的作用是解決瀏覽器用戶與web服務器之間無狀態通信。
二、注意點
cookie的大小和數量是有限製的。
cookie在個人硬盤上所保存的文本信息是以明文格式進行保存的,沒有任何的加密措施。
瀏覽器可以設定不使用cookie。
三、代碼
cookiesInput.html
<html>
<head>
<title>cookie input page</title>
<meta http-equiv="content-type" content="text/html; charset=UTF-8">
</head>
<body>
請輸入用戶名<br>
<form name="form1" action="SetCookiesServlet" method="post" >
<table border="0">
<tr><td>用戶名:</td>
<td><input type="text" name="username">
</td></tr>
<tr><td colspan="2" align="center">
<input name="submit" value="submit" type="submit">
</td></tr>
</table>
</form>
</body>
</html>
SetCookiesServlet
import java.io.IOException;
import java.io.PrintWriter;
import java.text.SimpleDateFormat;
import java.util.Date;
import javax.servlet.ServletException;
import javax.servlet.http.Cookie;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import webbook.util.StringUtil;
public class SetCookiesServlet extends HttpServlet {
public void doPost(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
String output = null;
String username = request.getParameter("username");
if (!StringUtil.validateNull(username)) {
Cookie cookie1 = new Cookie("username", StringUtil.filterHtml(username));
// cookie的有效期為1個月
cookie1.setMaxAge(24 * 60 * 60 * 30);
response.addCookie(cookie1);
SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");
Cookie cookie2 = new Cookie("lastTime", sdf.format(new Date()));
cookie2.setMaxAge(24 * 60 * 60 * 30);
response.addCookie(cookie2);
output = "本次登錄時間與用戶名已經寫到Cookie中";
}
else {
output = "用戶名為空,請重新輸入";
}
response.setContentType("text/html;charset=UTF-8");
PrintWriter out = response.getWriter();
out.println("<html>");
out.println("<head><title>set cookies </title></head>");
out.println("<body>");
out.println("<h2>" + output + "</h2>");
out.println("</body>");
out.println("</html>");
out.flush();
out.close();
}
}
GetCookiesServlet
import java.io.IOException;
import java.io.PrintWriter;
import javax.servlet.ServletException;
import javax.servlet.http.Cookie;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
public class GetCookiesServlet extends HttpServlet {
public void doPost(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
response.setContentType("text/html;charset=UTF-8");
PrintWriter out = response.getWriter();
// 獲取所有的cookie值
Cookie[] cookies = request.getCookies();
Cookie cookie = null;
for (int i = 0; i < cookies.length; i++) {
cookie = cookies[i];
if (cookie.getName().equals("username")) {
out.println("用戶名:" + cookie.getValue());
}
if (cookie.getName().equals("lastTime")) {
out.println("上次登錄時間:" + cookie.getValue());
}
}
out.flush();
out.close();
}
}
源代碼的作者是XHW,日期是2011-7-22
四、銷毀Cookie
Cookie cookies[] = request.getCookies();
if (cookies != null)
{
for (int i = 0; i < cookies.length; i++)
{
cookies[i].setMaxAge(0);
response.addCookie(cookies[i]);
}
}
原帖地址:https://www.cnblogs.com/hongten/archive/2011/07/22/2114448.html
最後更新:2017-04-03 21:30:17