开启 J2EE(五)— Servlet之状态管理
HTTP无状态协议
首先我们要知道:
HTTP协议是无状态协议。
我们知道HTTP协议就是server通过Request从浏览器接收和Response向浏览器输出的这么一个过程(浏览器和server的交互过程)。
所谓无状态也就是完毕一个过程后(client和server
就断开了),下一个过程假设须要前面的信息,它还须要又一次进行一次,server不能记住上次的请求。
这样可能就是在频繁进行同样的请求传送时,数据量增大,效率减少。所以,假设在server不须要先前信息时它的应答就较快。
那么,怎样让server知道不同的请求是否来自同一个client。就状态管理问题出现了Cookie和Session。
Cookie
Cookie保存在client,有两种实现方式。
方式一
将Cookie保存到浏览器内存中
1
保存Cookie。
写到client(addCookie())
public class SetCookie extends HttpServlet { public void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException { Cookie c1 = new Cookie("password","123");
response.addCookie(c1);
}
}
Cookie以键值对的形式进行保存。
2
读取Cookie(通过Http协议传过去的)
public class ShowCookie extends HttpServlet { public void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException { Cookie[] Cookies = request.getCookies();
for(int i=0; i<Cookies[i];i++){
Cookie c = Cookies[i];
reponse.getWriter().Println(c.getName() + "," + c.getValue());
}
}
}
此方式,Cookie仅仅能在当前浏览器窗体和子窗体中有效。重开浏览器无效。所以有一定的限制。
方式二
将Cookie保存到文本文件
文件怎样生成的,通过限制Cookie的生命期。然后在写到client,就能够生成文本文件了。
例如以下例。拿到clientIP的样例:
1
保存Cookie。写到client文本文件
public class SetCookie extends HttpServlet { public void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException { <span style="font-family:SimSun;"> //<span lang="zh-CN" style="font-family:SimSun;">获取</span><span lang="en-US" style="font-family:Calibri;">IP</span><span lang="zh-CN" style="font-family:SimSun;">地址</span></span>
Cookie c2 = new Cookie("client_ip",request.getRemoteAddr()); //设置Cookie的生命周期为1小时,单位秒
c2.setMaxAge(60*60);
response.addCookie(c2); response.getWriter().println("SetCookie OK");
}
}
2 读取Cookie。同方式一,略。
Cookie说明:
上面两种方式都是通过Servlet创建一个 Cookie对象,存储键-值对。
1、通过 response的 addCookie方法将该 Cookie信息加入到对应信息中。
2、再通过request.getCookies()方法获取到Cookie信息。
3、总的来说cookie机制採用的是在client保持状态的方案。
它是在client的会话状态的存储机制,他须要用户打开client的cookie支持。
4、不足:因为Cookie是保存在client的,相对存在较大的安全隐患。且一般浏览器对 Cookie的数目及数据大小有严格的限制。所以对一些小数量,安全性的信息,普通情况下通过Session存储。
Session
Session保存在服务端。
因为Session的是将会话保存在服务端。关闭浏览器(或新开)就没了。可是这么多的用户Session,怎样区分?这就须要一个SessionID。每个SessionID都指向了唯一的一个用户会话。
可是client怎样知道SessionID呢,方式有两种。
方式一
在Cookie中保存SessionID
watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvYWtremhqag==/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/SouthEast" alt="">
public void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException { //获得 HttpSession对象
HttpSession session = request.getSession();
//设置 Session对象的最长不活动间隔
session.setMaxInactiveInterval(30); //获取 Session中的数据
List list = (List)session.getAttribute("list");
if (list == null) {
list = new ArrayList();
list.add("hey");
//向 Session中加入数据
session.setAttribute("list", list);
}
}
方式二
假设禁用了Cookie?通过URL重写,SessionId能够保存在URL后面
URL重写:
public class UrlRewriterSession extends HttpServlet { public void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException { HttpSession session = request.getSession(true);
response.getWriter().println("<a href= '" + response.encodeURL(request.getRequestURL().toString()) + "'>UrlRewrite</a>");
}
}
不论client是否禁用Cookie。
假设想安全使用Session。仅仅能使用URL重写,但对应的会添加编程负担,所以有时站点要求client打开Cookie。
总结
相比Cookie,Session事实上在之前ASP.net中已经用的非常多了。当时真是认为真好用。把值放到Session中。什么时候用直接取,不用再查数据库了,太方便了,以至于快到了滥用的趋势。然而过度使用session将会导致代码不可读并且不好维护,并且Session的默认失效期是30分钟。假设在Session中放入了大的对象,server的压力可想而知。
所以Session的使用也须要有度。
开启 J2EE(五)— Servlet之状态管理的更多相关文章
- 五、vue状态管理模式vuex
一.vuex介绍 Vuex 是一个专为 Vue.js 应用程序开发的状态管理模式.它采用集中式存储管理应用的所有组件的状态,并以相应的规则保证状态以一种可预测的方式发生变化. 即data中属性同时有一 ...
- 实验五 ASP.NET状态管理和应用程序配置 总结
这次实验内容是对ASP.NET配置系统的了解和使用,还有就是对Application.Session.ViewState对象的应用.首先,我想说ASP.NET配置系统真的大大超乎我的想象,我以为会是上 ...
- Vue之状态管理(vuex)与接口调用
Vue之状态管理(vuex)与接口调用 一,介绍与需求 1.1,介绍 1,状态管理(vuex) Vuex 是一个专为 Vue.js 应用程序开发的状态管理模式.它采用集中式存储管理应用的所有组件的状态 ...
- Servlet学习笔记06——什么是转发,路径,状态管理?
1.include指令 (1)作用: 告诉容器,在将jsp转换成Servlet时,将 某个文件的内容插入到该指令所在的位置. (2)语法: <%@ include file="&quo ...
- saltstack(五) saltstack的state状态管理
一,YAML语法 首先先了解一下YAML,默认的SLS文件的renderer是YAML renderer.YAML是一个有很多强大特性的标记性语言.Salt使用了一个YAML的小型子集,映射非常常用的 ...
- 通过Dapr实现一个简单的基于.net的微服务电商系统(五)——一步一步教你如何撸Dapr之状态管理
状态管理和上一章的订阅发布都算是Dapr相较于其他服务网格框架来讲提供的比较特异性的内容,今天我们来讲讲状态管理. 目录:一.通过Dapr实现一个简单的基于.net的微服务电商系统 二.通过Dapr实 ...
- 为windows开启winrm service, 以便进行远程管理
为windows开启winrm service, 以便进行远程管理 是windows 一种方便远程管理的服务:开启winrm service,便于在日常工作中,远程管理服务器,或通过脚本,同时管理 ...
- Flink状态管理与状态一致性(长文)
目录 一.前言 二.状态类型 2.1.Keyed State 2.2.Operator State 三.状态横向扩展 四.检查点机制 4.1.开启检查点 (checkpoint) 4.2.保存点机制 ...
- [译]面向初学者的Asp.Net状态管理技术
介绍 本文主要讲解Asp.Net应用程序中的状态管理技术(Asp.Net中有多种状态管理技术),并批判性地分析所有状态管理技术的优缺点. 背景 HTTP是无状态的协议.客户端发起一个请求,服务器响应完 ...
随机推荐
- simpleOS 1.0
做了一个so simple的OS,本不好意思多说的....不过还是说下吧. 首先,买不起开发板的我没有办完完成一件事,那就是保存任务上下文,因为这个过程实际上是将寄存器的值存放到任务堆栈中去的. 而要 ...
- 可持久化Treap(fhq Treap,非旋转式Treap)学习(未完待续)
简介: Treap,一种表现优异的BST 优势: 其较于AVL.红黑树实现简单,浅显易懂 较于Splay常数小,通常用于树套BST表现远远优于Splay 或许有人想说S ...
- lowbit( )运算
--------开始-------- lowbit (n) 定义为非负整数n在二进制表示下“最低位的1及其后面所有的0构成的数值. 比如: n = 10 的二进制下为1010,则lowbit (n) ...
- 浅谈自学Python之路(day3)
今天的主要内容是: 撒 文件操作 对文件操作的流程: 打开文件,得到文件句柄并赋值给一个变量 通过句柄对文件进行操作 关闭文件 现有文件如下: tonghuazhen 听说白雪公主在逃跑 小红帽在担心 ...
- Django day06 模版层(一) 变量和深度查询
一.模版语法之变量: 1 - {{ 变量 }} ******重要*******{#这个相当于print了该变量#} def index(request): name = 'prince' #字符串 ...
- Python 34(进程了解)
一:僵尸进程与孤儿进程 测试程序: 基本概念: 一个进程使用fork创建子进程,如果子进程退出,而父进程并没有调用wait或waitpid获取子进程的状态信息,那么子进程的进程描述符仍然保存在系统中. ...
- Springboot统一跨域配置
前言:跨域是什么? 要知道跨域的概念,我们先明确怎样算是同一个域: 同一个域指的是同一协议,同一ip,同一端口 如果这三同中有一者不同就产生了跨域. 在做前后端分离的项目中,通过ajax请求后台端口时 ...
- oen /var/run/nginx.pid failed
nginx: [error] open() "/var/run/nginx.pid" failed (2: No such file or directory) [root@TES ...
- ruby --Paperclip::NotIdentifiedByImageMagickError
首先,如果遇到这个问题,Paperclip::NotIdentifiedByImageMagickError,先检查下环境变量是否配置了ImagicMagick的路径. cmd下path 查看,首先加 ...
- Could not create the view: An unexpected exception was thrown. Myeclipse空间报错
我的路径D:\MyEclipse 10\.metadata\.plugins\org.eclipse.core.runtime\.settings 我也遇到过这个问题,就是工作空间的问题好像是删除你工 ...