JSP编程技巧:用JSP操作Cookie

一、 前言

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

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

二、 写入Cookie

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

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

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

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

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

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

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

三、 读出Cookie

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

<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><%=name%></td><td><%=svalue%></td></tr>
<%
}
%>
</table>
........(其他内容)
</body>
</html>

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

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

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

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

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

四、 需要注意的一些问题

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

  1. Cookie的兼容性问题

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

  2. Cookie的内容

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

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

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
1. Cookie和Session的工作原理: - Cookie:当用户访问一个网站时,服务器会发送一个Cookie到用户的浏览器浏览器保存这个Cookie。当用户再次访问该网站时,浏览器会将Cookie发送给服务器,服务器根据Cookie中的信息来识别用户。一个Cookie通常包含一个名字、一个值和过期时间。 - Session:当用户第一次访问一个网站时,服务器为该用户创建一个Session,生成一个Session ID,将该Session ID通过Cookie发送给用户浏览器。当用户再次访问该网站时,浏览器会将Session ID发送给服务器,服务器根据Session ID来识别用户。Session通常用于保存用户的状态信息,如登录状态、购物车等。 2. Cookie和Session的区别: - 存储位置:Cookie存储在客户端浏览器,Session存储在服务器端。 - 安全性:Cookie不太安全,因为Cookie中的信息可以被用户查看和修改;Session相对较安全,因为Session信息保存在服务器端,用户无法直接查看和修改。 - 存储容量:Cookie存储容量比较小,一般只能存储4KB左右的数据;Session存储容量比较大,一般可以存储几MB的数据。 - 过期时间:Cookie可以设置过期时间,可以长期保存在客户端浏览器中;Session默认情况下在客户端浏览器关闭后就会失效。 3. JSP的基本原理: JSP是一种基于Java技术的动态网页开发技术,其基本原理就是将Java代码嵌入到HTML页面中,通过JSP引擎将JSP页面转换为Servlet,然后由Servlet容器来处理Servlet,生成HTML输出。 4. JSP指令和标签: - JSP指令:使用<%@ %>标签来定义JSP页面的属性和导入其他文件。如:<%@ page language="java" contentType="text/html; charset=UTF-8" %> - JSP标签:使用<% %>标签来嵌入Java代码,使用<%= %>标签来输出表达式的值。如:<% for(int i=0;i<10;i++){ %> Hello <%=i%> <% } %> 5. JSP隐式对象: JSP隐式对象是JSP引擎自动创建的一些对象,可以在JSP页面中直接使用,无需声明和实例化。常用的JSP隐式对象包括: - request:HttpServletRequest对象,表示客户端发来的请求。 - response:HttpServletResponse对象,表示服务器发送给客户端的响应。 - session:HttpSession对象,表示客户端和服务器之间的会话。 - application:ServletContext对象,表示整个Web应用程序。 - out:JspWriter对象,表示输出流,用于将响应写入到浏览器中。 6. EL和JSTL: - EL:Expression Language,表达式语言,用于在JSP页面中访问JavaBean的属性和方法。如:${user.name} - JSTL:JSP Standard Tag Library,JSP标准标签库,提供了一组标准的标签,用于简化JSP页面中的开发。如:<c:forEach>、<c:if>、<c:choose>等。 7. JavaBean概述、概念、规范: JavaBean是一种符合JavaBean规范的Java类,用于封装数据,并提供一组标准的访问方法(get/set方法)。JavaBean通常用于在Web开发中,作为数据模型传递给JSP页面或Servlet。 JavaBean的规范包括: - 类名:JavaBean的类名必须以大写字母开头,且不包含下划线。 - 属性:JavaBean的属性必须是私有的,且提供对应的get/set方法。 - 默认构造函数:JavaBean必须有一个无参的默认构造函数。 - 可序列化:JavaBean必须实现Serializable接口,以便在网络传输或保存到文件中使用。 8. MVC设计模式: MVC是一种常见的软件架构设计模式,将应用程序分为三个部分:模型(Model)、视图(View)和控制器(Controller)。 - 模型:用于封装数据和业务逻辑,主要负责数据的访问和处理。 - 视图:用于展示数据,主要负责用户界面的显示。 - 控制器:用于处理用户请求,主要负责调度模型和视图之间的交互。 MVC模式的优点包括: - 分离关注点:将应用程序分为三个部分,各自负责不同的任务,易于维护和扩展。 - 代码可重用:模型和视图可以在不同的应用程序中重用。 - 提高开发效率:开发人员可以并行开发不同的部分,提高开发效率。 9. 反射: 反射是Java语言的一个重要特性,指程序可以在运行时获取和操作类的信息、对象的属性和方法。反射可以让程序在运行时动态地创建对象、调用方法、访问属性,具有很高的灵活性和扩展性。 常见的反射API包括: - Class类:表示一个类或接口。 - Constructor类:表示一个构造函数。 - Field类:表示一个类的属性。 - Method类:表示一个方法。 编程题: 请编写一个Java程序,使用反射机制动态创建一个Person对象,并设置其属性值为name="Tom",age=18,然后输出该对象的属性值。 ```java import java.lang.reflect.Field; public class Test { public static void main(String[] args) throws Exception { Class clazz = Class.forName("Person"); // 获取Person类的Class对象 Object obj = clazz.newInstance(); // 创建Person对象 Field nameField = clazz.getDeclaredField("name"); // 获取name属性 nameField.setAccessible(true); // 设置允许访问私有属性 nameField.set(obj, "Tom"); // 设置name属性值 Field ageField = clazz.getDeclaredField("age"); // 获取age属性 ageField.setAccessible(true); // 设置允许访问私有属性 ageField.set(obj, 18); // 设置age属性值 System.out.println(obj); // 输出Person对象的属性值 } } class Person { private String name; private int age; public Person() {} public String getName() { return name; } public void setName(String name) { this.name = name; } public int getAge() { return age; } public void setAge(int age) { this.age = age; } @Override public String toString() { return "Person{" + "name='" + name + '\'' + ", age=" + age + '}'; } } ```

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值