如何实现不同页面之间的数据传递,实现页面的数据共享?常见的方法有以下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没有任何影响。

最新文章

  1. ABP框架 - 缓存
  2. 设置ASP.NET MVC站点默认页为.html页 .
  3. http 中定义的八种请求的介绍
  4. JDBC查询指定条件的数据
  5. Java里Serializable的那些事
  6. 理解Docker容器的进程管理
  7. (转)关于Certificate、Provisioning Profile、App ID的介绍及其之间的关系
  8. 弃用的异步get和post方法之代理方法
  9. 6-JS函数(二)
  10. windows下编译ffmpeg
  11. UILabel自适应高度,自动换行
  12. 正式学习React(一) 开始学习之前必读
  13. [转]intent 传递对象
  14. hdu 6045 Is Derek lying?(思维推导)
  15. 走进 Visual Studio Mobile Center for Xamarin.Forms
  16. NGUI_概述
  17. CentOS 7下Samba服务器的安装与配置
  18. 服务化改造实践 | 如何在 Dubbo 中支持 REST
  19. 自学stm32的一些个人经验
  20. js时间国际化

热门文章

  1. Spring Cloud 配置服务
  2. Codeforces Round #380 (Div. 2) 总结分享
  3. 深入入门系列--Data Structure--04树
  4. TSQL HASHBYTES 用法
  5. jQuery插件之ajaxFileUpload
  6. HTML5移动Web开发(七)——通过界面图标启动Web应用
  7. UML简介
  8. Spark入门实战系列--2.Spark编译与部署(下)--Spark编译安装
  9. java类的初始化和对象的创建顺序
  10. 安装elasticsearch及中文IK和近义词配置