jsp另外五大内置对象之response
分类:web前端

Cookie应该是一种应用较久的技术了。早在HTML刚刚出现的时候,在每个独立的页面之间没有办法记录和标识不同的用户。后来人们就发明了Cookie技术,当用户访问网页时,它能够在访问者的机器上创立一个文件,我们把它叫作Cookie,写一段内容进去,来标识不同的用户。如果下次用户再访问这个网页的时候,它又能够读出这个文件里面的内容,这样网页就知道上次这个用户已经访问过该网页了。

responseo3.jsp

先来看看效果图:

虽然现在网页的制作技术比起几年以前已经发展了许多。不过有些时候,Cookie还是能够帮我们很多忙的。接下来,我们就来看看,如何在写JSP文件的时候,用JSP操作Cookie.

<%@ page language="java" contentType="text/html; charset=utf-8"
pageEncoding="utf-8"%>
<%@ page import="java.util.*"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" ";
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<title>Insert title here</title>
<script type="text/javascript">
function resetValue(){
document.getElementById("userName").value="";
document.getElementById("pwd").value="";
}
</script>
<%
String userName=null;
String pwd=null;
Cookie[] cookies=request.getCookies();
for(int i=0;cookies!=null &&i<cookies.length;i++){
if(cookies[i].getName().equals("userNameAndPwd")){
userName=cookies[i].getValue().split("-")[0];
pwd=cookies[i].getValue().split("-")[1];
}
}

图片 1

写入Cookie

if(userName==null){
userName="";
}

 

其实用JSP操作Cookie是非常简单的,我们来看下面一段JSP程序:

if(pwd==null){
pwd="";
}
%>
</head>
<body>

点击submit后:

<html>
  <head>……(中间略)
  </head>
  <body>
  <%
  String cookieName="Sender";
  Cookie cookie=new Cookie(cookieName, "Test_Content");
  cookie.setMaxAge(10);
  response.addCookie(cookie);
  %>
  ……(其他内容)
  </body>
  </html>

<form action="userLogin.jsp" method="post">
<table>
<tr>
<td>用户名:</td>
<td><input type="text" id="userName" name="userName" value="<%=userName%>"/></td>
</tr>
<tr>
<td>密码:</td>
<td><input type="password" id="pwd" name="pwd" value="<%=pwd %>" /></td>
</tr>
<tr>
<td>记住密码:</td>
<td><input type="checkbox" id="remember" name="remember" value="remember-me"/></td>
</tr>
<tr>
<td><input type="submit" value="登录"/></td>
<td><input type="button" value="重置" onclick="resetValue()"/></td>
</tr>
</table>
</form>
</body>
</html>

图片 2

这样我们就设置了一个Cookie,很简单吧?

 

点击查看Cookies:

我们来仔细研究一下这段代码:

 

图片 3

Cookie cookie=new Cookie(cookieName, "Test_Content");

userLogin.jsp

在C:Documents and SettingsAdministratorCookies目录下面会有一个   hongten@webproject_cookie%5B2%5D.txt  的文件;

这一行建立了一个Cookie对象,初始化有两个参数,第一个参数cookieName定义了Cookie的名字,后一个参数,也是一个字符串,定义了Cookie的内容。也就是我们希望网页在用户的机器上标识的文件内容。

<%@ page language="java" contentType="text/html; charset=utf-8"
pageEncoding="utf-8"%>
<%@ page import="javax.servlet.http.*"%>

这就是cookie的文件;

接下来一行:cookie.setMaxAge(10),调用了Cookie中的setMaxAge方法,设定Cookie在用户机器硬盘上的存活期为10秒。一个Cookie在用户的硬盘里面存在的时间并不是无限期的,在建立Cookie对象的时候,我们必须制定Cookie的存活期,超过了这个存活期后,Cookie文件就不再起作用,会被用户的浏览器自行删除。如果我们希望用户在下次访问这个页面的时候,Cookie文件仍然有效而且可以被网页读出来的话,我们可以将Cookie的存活期设得稍微长一些。比如cookie.setMaxAge(365*24*60*60)可以让Cookie文件在一年内有效
读出Cookie

<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" ";
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<title>Insert title here</title>
</head>
<body>
<%
String userName=request.getParameter("userName"); // 获取用户名
String pwd=request.getParameter("pwd"); // 获取密码
String remember=request.getParameter("remember"); // 获取记住密码

 

Cookie文件创建好后,自然还需要我们把它读出来,否则我们不是白费力气吗?接下来我们看看如何读出在用户硬盘上的Cookie.

if("remember-me".equals(remember)){
Cookie userNameAndPwd=new Cookie("userNameAndPwd",userName+"-"+pwd);
userNameAndPwd.setMaxAge(1*60*60*24*7); // cookie记录一个星期
response.addCookie(userNameAndPwd); // 保存cookie
System.out.println("设置Cookie成功");
}
response.sendRedirect("response03.jsp");
%>

 

  <html>
  <head>……(中间略)
  </head>
  <body>
  <table border=1>
  <tr><td>Name</td><td>value</td></tr>
  <%
  Cookie cookies[]=request.getCookies();
  Cookie sCookie=null;
  String svalue=null;
  String sname=null;
  for(int i=0;i<cookies.length;i++)
  {
  sCookie=cookies[i];
  svalue=sCookie.getValue();
  sname=sCookie.getName();
  %>
  <tr><td><%=sname%></td><td><%=svalue%></td></tr>
  <%
  }
  %>
  </table>……(其他内容)
  </body>
  </html>

</body>
</html>

再来看看代码是怎样实现的:

这一小段JSP文件可以读出用户硬盘上的所有有效的Cookie,也就是仍然在存活期内的Cookie文件。并用表格的形式列出每个Cookie的名字和内容。

 

cookiesInput.html

我们来逐行分析一下这段代码:

代码:

Cookie cookies[]=request.getCookies() 我们用request.getCookies()读出用户硬盘上的Cookie,并将所有的Cookie放到一个cookie对象数组里面。

<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>

接下来我们用一个循环语句遍历刚才建立的Cookie对象数组,我们用sCookie=cookies[i]取出数组中的一个Cookie对象,然后我们用sCookie.getValue()和sCookie.getName()两个方法来取得这个Cookie的名字和内容。

 

  通过将取出来的Cookie的名字和内容放在字符串变量中,我们就能对其进行各种操作了。在上面的例子里,可通过循环语句的遍历,将所有Cookie放在一张表格中进行显示。

 

需要注意的一些问题

 

通过上面两个简单的例子,可以看到,用JSP进行Cookie的操作,是非常简单的。不过我们在实际操作中还要注意一些问题:

SetCookiesServlet.java

  1. Cookie的兼容性问题

代码:

Cookie的格式有2个不同的版本,第一个版本,我们称为Cookie Version 0,是最初由Netscape公司制定的,也被几乎所有的浏览器支持。而较新的版本,Cookie Version 1,则是根据RFC 2109文档制定的。为了确保兼容性,JAVA规定,前面所提到的涉及Cookie的操作都是针对旧版本的Cookie进行的。而新版本的Cookie目前还不被Javax.servlet.http.Cookie包所支持。

/**
 *
 */
package webbook.chapter6;

  1. Cookie的内容

import java.io.IOException;
import java.io.PrintWriter;
import java.text.SimpleDateFormat;
import java.util.Date;

同样的Cookie的内容的字符限制针对不同的Cookie版本也有不同。在Cookie Version 0中,某些特殊的字符,例如:空格,方括号,圆括号,等于号(=),逗号,双引号,斜杠,问号,@符号,冒号,分号都不能作为Cookie的内容。这也就是为什么我们在例子中设定Cookie的内容为“Test_Content”的原因。

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

虽然在Cookie Version 1规定中放宽了限制,可以使用这些字符,但是考虑到新版本的Cookie规范目前仍然没有为所有的浏览器所支持,因而为保险起见,我们应该在Cookie的内容中尽量避免使用这些字符

import webbook.util.StringUtil;

/**
 *
 * @author XHW
 *
 * @date 2011-7-22
 *
 */
public class SetCookiesServlet extends HttpServlet {

 private static final long serialVersionUID = 6849802930688070121L;

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

 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);
   SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");
   Cookie cookie2 = new Cookie("lastTime", sdf.format(new Date()));
   cookie2.setMaxAge(24 * 60 * 60 * 30);
   response.addCookie(cookie1);
   response.addCookie(cookie2);
   output = "本次登录时间与用户名已经写到Cookie中。<br><a href="/webproject_cookie/GetCookiesServlet">查看Cookies</a>";
  } else {
   output = "用户名为空,请重新输入。<br><a herf="/webproject_cookie/cookieInput.htm">输入用户名</a>";
  }

  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.java

代码:

/**
 *
 */
package webbook.chapter6;

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;

/**
 *
 * @author XHW
 *
 * @date 2011-7-22
 *
 */
public class GetCookiesServlet extends HttpServlet {

 private static final long serialVersionUID = -156960358689563625L;

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

 public void doPost(HttpServletRequest request, HttpServletResponse response)
   throws ServletException, IOException {
  response.setContentType("text/html;charset=UTF-8");
  PrintWriter out = response.getWriter();
  out.println("<html>");
  out.println("<head><title>display login infomation</title></head>");
  out.println("<body>");
  out.println("<h2>从Cookie中获得上次登录时间与用户名</h2>");

//获取所有的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());
    out.println("<br>");
   }
   if (cookie.getName().equals("lastTime")) {
    out.println("上次登录时间:" + cookie.getValue());
    out.println("<br>");
   }
  }
  out.println("</body>");
  out.println("</html>");
  out.flush();
  out.close();
 }
}

 

 

cookie是web服务器通过浏览器保存在www用户端硬盘上的一个文本文件,这个文件中包含了文本信息

文本信息的内容是以“名/值”对(key/value)的形式进行储存的

可以让web开发者通过程序读写这个文本文件

在Windows XP中保存Cookie的目录是:C:Documents and Settings用户名Cookies

 

 

Cookie的作用:

  解决浏览器用户与web服务器之间无状态通信

 

 

使用cookie的时候注意的事项:

  cookie的大小和数量是有限制的

  cookie在个人硬盘上所保存的文本信息是以明文格式进行保存的,没有任何的加密措施

  浏览器可以设定不使用cookie 

 

本文由10bet手机官网发布于web前端,转载请注明出处:jsp另外五大内置对象之response

上一篇:没有了 下一篇:没有了
猜你喜欢
热门排行
精彩图文