Servlet中会话之cookie(7)

2024-06-14 18:58
文章标签 servlet cookie 中会

本文主要是介绍Servlet中会话之cookie(7),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1.(1).用户输出URL地址,有效访问某个网站,在该网站上的一系列有效操作,随后关闭浏览器的整个过程,叫一次会话
   (2).会话主要解决服务端如何保存每个客户端对应的私有信息。
   (3).会话主要有二种:
a>Cookie技术[客户端技术]

b>Session技术

两者的不同就是:session会随着浏览器关闭而失效,但cookie会一直存放在客户端机器上,除非超出Cookie的生命周期。

2.Cookie技术

   (1)Cookie是客户端技术,服务器把每个用户的数据以cookie的形式写给用户各自的浏览器。当用户使用浏览器再去访问服务器中的web资源时,就会带着各自的数据去。这样,web资源处理的就是用户各自的数据了。
   (2)一个Cookie只能存储一种类型的信息
   (3)更新某个名的Cookie,即向浏览器写一个相同名的Cookie
   (4)Cookie一定要设置一个有效时间,如果不设置的话,默认该请求访问结束后,该Cookie自动销毁,用专业名词来讲,Cookie的默认有效期时一个有效会话结束

3.Cookie的理解图







4.Cookie要注意的地方:

(1)一个Cookie只能标识一种信息,它至少含有一个标识该信息的名称(NAME)和设置值(VALUE)。 
(2)一个WEB站点可以给一个WEB浏览器发送多个Cookie,一个WEB浏览器也可以存储多个WEB站点提供的Cookie。
(3)浏览器一般只允许存放300个Cookie,每个站点最多存放20个Cookie,每个Cookie的大小限制为4KB。
(4)如果创建了一个cookie,并将他发送到浏览器,默认情况下它是一个会话级别的cookie(即存储在浏览器的内存中),用户退出浏览器之后即被删除。若希望浏览器将该cookie存储在磁盘上,则需要使用maxAge,并给出一个以秒为单位的时间。将最大时效设为0则是命令浏览器删除该cookie。
注意,删除cookie时,path必须一致,否则不会删除


5.代码小小练习:

package cn.wwh.www.web.cookie;
import java.io.IOException;
import java.io.PrintWriter;
import java.net.URLDecoder;
import java.net.URLEncoder;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的创建和获取其中的数据值 注意1.对于返回的cookie一定对其进行非空的判断* 2.对于编码方式采用UTF-8的方式,运行结果出现异常了,* 而采用 gbk的方式却正常输出,很是奇怪,(英文不需要转码)* * *@author 一叶扁舟*@version 1.0*@创建时间: 2014-8-1 下午04:52:31*/
public class CreateCookie extends HttpServlet {public void doGet(HttpServletRequest request, HttpServletResponse response)throws ServletException, IOException {// 在服务端创建一个CookieCookie name = new Cookie("name", URLEncoder.encode("一叶扁舟", "gbk"));// 设置cookie的存活时间name.setMaxAge(1 * 24 * 60 * 60);// 服务器将cookie写到客户端的缓存中response.addCookie(name);// 取出客户端中所有的cookieCookie[] allCookie = request.getCookies();Cookie nameCookie = null;if (allCookie != null) {for (Cookie cookie : allCookie) {System.out.println("cookieName:" + cookie.getName());if (cookie.getName().equals("name")) {nameCookie = cookie;break;}}}// 输出cookie的信息System.out.println("cookie的name:" + nameCookie.getName());System.out.println("cookie的value:"+ URLDecoder.decode(nameCookie.getValue()));System.out.println("cookie的version:" + nameCookie.getVersion());System.out.println("cookie的path:" + nameCookie.getPath());System.out.println("cookie存活时间:" + nameCookie.getMaxAge());}
}


6.代码练习2:
package cn.wwh.www.web.cookie;import java.io.IOException;
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;/***类的作用:利用cookie技术,显示用户上次访问的时间* * *@author 一叶扁舟*@version 1.0*@创建时间: 2014-8-1 下午08:38:14*/
public class ShowVisitedTime extends HttpServlet {public void doGet(HttpServletRequest request, HttpServletResponse response)throws ServletException, IOException {String name = request.getParameter("name");if (name == null) {name = "default";}// 获取客户端的cookieCookie[] cookies = request.getCookies();if (cookies == null) {Cookie nameCookie = new Cookie("name_" + name, System.currentTimeMillis()+ "");// 设置cookie缓存时间为一个小时nameCookie.setMaxAge(1 * 60 * 60);// 写到客户端的缓存response.addCookie(nameCookie);response.setContentType("text/html;charset=UTF-8");response.getWriter().write("欢迎" + "您首次光临本网站,当前时间为:" + new Date().toLocaleString());} else {Cookie c = null;for (Cookie cookie : cookies) {// 找到了改用户之前登陆过if (cookie.getName().equals("name_" + name)) {c = cookie;break;}}if (c != null) {response.setContentType("text/html;charset=UTF-8");// 获取上次访问的时间String lastTimeStr = c.getValue();Long lastTime = Long.parseLong(lastTimeStr);response.getWriter().write("欢迎" + "您再次访问本网站,上次访问时间为:"+ new Date(lastTime).toLocaleString());Cookie nameCookie = new Cookie("name_" + name, System.currentTimeMillis()+ "");// 设置cookie缓存时间为一个小时nameCookie.setMaxAge(1 * 60 * 60);// 写到客户端的缓存response.addCookie(nameCookie);}}}
}

浏览器的效果图:



之后的刷新:

缓存文件的截图:


这篇关于Servlet中会话之cookie(7)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1061251

相关文章

JavaEE7 Servlet 3.1(JSR 340)规范中文版

http://www.iteye.com/news/27727-jinnianshilongnian     Jave EE 7中的部分规范已正式获得批准通过,其中包括JSR340 Java Servlet 3.1规范,去年翻译了该规范,在此分享出来,希望对某些朋友有所帮助,不足之处请指正。   点击直接下载    在线版目录   Servlet3.1规范翻译

JavaScript中document.cookie

“某些 Web 站点在您的硬盘上用很小的文本文件存储了一些信息,这些文件就称为 Cookie。”—— MSIE 帮助。一般来说,Cookies 是 CGI 或类似,比 HTML 高级的文件、程序等创建的,但是 javascript 也提供了对 Cookies 的很全面的访问权利。       每个 Cookie 都是这样的:<cookie名>=<值>   <cookie名>的限制与 javasc

请解释Java Web应用中的前后端分离是什么?它有哪些好处?什么是Java Web中的Servlet过滤器?它有什么作用?

请解释Java Web应用中的前后端分离是什么?它有哪些好处? Java Web应用中的前后端分离 在Java Web应用中,前后端分离是一种开发模式,它将传统Web开发中紧密耦合的前端(用户界面)和后端(服务器端逻辑)代码进行分离,使得它们能够独立开发、测试、部署和维护。在这种模式下,前端通常通过HTTP请求与后端进行数据交换,后端则负责业务逻辑处理、数据库交互以及向前端提供RESTful

Jasperreports+jaspersoft studio 实现单个或多个jrxml(jasper)文件生成一个pdf文件,并利用Servlet发送该pdf文件到浏览器中展示

Jasperreports+jaspersoft studio 实现单个或多个jrxml(jasper)文件生成一个pdf文件,并利用Servlet发送该pdf文件到浏览器中展示; 代码如下: Demo07.jrxml <?xml version="1.0" encoding="UTF-8"?><!-- Created with Jaspersoft Studio version 6.6.

servlet用反射代替if..else

String methodName = request.getParameter("method"); Method method = this.getClass().getDeclaredMethod(methodName,HttpServletRequest.class, HttpServletResponse.class); method.invoke(this, request, re

flask-login 生成 cookie,session

flask-login 生成 cookie,session Flask-Login login_user() 显示来自 Set-Cookie 标头的加密 cookie # 模拟一个用户类class User(UserMixin):def __init__(self, id):self.id = id@app.route('/login')def login():# 模拟用户登录过程user

【Http 每日一问,访问服务端的鉴权Token放在header还是cookie更合适?】

结论先行: token静态的,不变的,放在header里面。 典型场景 ,每次访问时需要带个静态token请求服务端,向服务端表明是谁请求,此时token也可以认为是个固定的access-key。token动态的,会失效,放在cookie里面。 典型场景,业务登录态token,存在有效期的,过一段时间可能会失效。 下面具体展开下。 在选择将鉴权 Token 放在 HTTP Header 还是

【Servlet】基础入门

1、使用 IDEA 建 javaWeb 及 Servlet http://blog.csdn.net/u012532559/article/details/51013400 2、doget与dopost的区别 http://www.cnblogs.com/cyy-13/p/5711235.html

剖析Cookie的工作原理及其安全风险

Cookie的工作原理主要涉及到HTTP协议中的状态管理。HTTP协议本身是无状态的,这意味着每次请求都是独立的,服务器不会保留之前的请求信息。为了在无状态的HTTP协议上实现有状态的会话,引入了Cookie机制。 1. Cookie定义 Cookie,也称为HTTP cookie、web cookie、互联网cookie或浏览器cookie,是一种用于在用户浏览网站时识别用户并为其准备

Servlet mapping specifies an unknown servlet name Action

看一下web.xml中<servlet-mapping>有没有配错