servlet同一用户不同页面共享数据

如何实现不同页面之间的数据传递,实现页面的数据共享?常见的方法有以下4种:

1)表单提交(form)

2)sendRedirect()跳转

3)session技术

4)Cookie技术

表单提交

这是最常见的一种方式,也是最简单的,但有时该技巧非常管用,形如:
<form action=login>

<input type=text name=a value=b>

<input type=hidden name=c value=d>

</form>
通过表单,我们也可以将一个页面信息,传递给另外的页面。特别注意隐藏表单的应用,如果不想讲提交的信息显示出来可以用它。

 

sendRedirect()跳转

sendRedirect("welcome?uname=xiangkejin");
优点:传送信息的速度比较快
缺点:它只能传送字符串,而不能传送一个对象
注意点:
1.welcome代表你要跳转的那个servlet的url
2.servlet url名和变量之间有?号
3.如要传递两个以上的值,它们间要用&号分开比如sendRedirect("welcome?uname=xiangkejin&PassWord=ok");
4.如果传递的是中文,那可能会是乱码,需要处理一下

 

session技术

当用户打开浏览器,访问某个网站时,服务器就会在服务器的内存中为该浏览器分配一个
空间,该空间被浏览器独占。
这个空间就是session空间,该空间中的数据默认存在时间30min,你也可以修改。
用处:
1.网上商城中的购物车
2.保存登录用户的信息
3.将某些数据放入到Session中,供同一用户的各个页面使用
4.防止用户非法登录到某个页面
session可以看做是一张表,这张表有两列。每一行即是session的一个属性
每个属性包含有两个部分,一个是该属性的名字(String)另一个是它的值(Object)

如何使用Session?
得到session的id,这是容器分配的,每个浏览器占有不是属于一个机器客户端,是属于一次请求
String sessionId=ht.getId();
1.得到session
HttpSession hs=req.getSession(true);
2.向session添加属性
hs.setAttribute(String name,Object val);
3.从session得到某个属性
String name=hs.getAttibute(String name);
4.从session删除某个属性
hs.removeAttribute(String name);
//这样讲删除全部的session
hs.setMaxInactiveInterval(0);

session的注意事项:
1.在web.xml中修改默认session时间30min,也可在程序中修改。可在tomcat中修改也可以在自己的站点修改
2.当某个浏览器访问网站时,服务器会给浏览器分配唯一一个session id,并以此来区分不同的浏览器
3.因为session的各个属性要占用服务器的内存,因此软件公司都是在迫不得已的情况下才使用

 

Cookie技术

cookie是服务器在客户端保存用户的信息这些信息就像是小甜饼一样,数据量不大,服务器端在需要的时候可以从客户端读取

一般保存在C:\Documents and Settings目录下

用处:
1.保存用户名、密码,在一定时间不用重新登录
2.记录用户访问网站的喜好
3.网站的个性化,定制网站的服务内容

如何使用Cookie?
1.Cookie优点像一张表,分两列,一个是名字,一个是值
数据类型都是String
2.如何创建一个Cookie(在服务器端创建的)
Cookie c=new Cookie(String name,String val);
3.如何将一个Cookie添加到客户端
response.addCookie(c)
4.如何读取Cookie(从客户端掉服务器)
Cookie [] cookie=request.getCookies();

其他说明:
1.可以通过IE-工具-Internet选项-隐私-高级来启用或是禁用cookie
2.由于cookie的信息是保存在客户端的,因此安全性不高
3.cookie信息的生命周期可以在创建时设置

Cookie和session的区别
1.存在的位置

 cookie保存在客户端,session保存在服务器端

2.安全性

cookie的安全性比session要弱。cookie是明文保存,session是保存在内存中

3.网络传输量

cookie通过网络在客户端与服务器端传输

session保存在服务器端,不需要传输

4.生命周期(20分钟为例)

     (1)cookie的生命周期是类的,从创建时,就开始计时,

         20分钟后cookie生命周期结束。

     (2)session的生命周期是间隔的,从创建时,开始计时如果在20分钟,

        没有访问过session,那么session信息五小,如果在20分钟内,

        访问过session,那么,它的生命周期将重新开始计算。

     (3)另外,关机会造成session生命周期结束,但是cookie没有任何影响。

posted @ 2016-07-21 20:46  开拖拉机的蜡笔小新  阅读(772)  评论(0编辑  收藏  举报