---------------------- <a href="http://edu.csdn.net"target="blank">ASP.Net+Android+IO开发S</a>、<a href="http://edu.csdn.net"target="blank">.Net培训</a>、期待与您交流! ----------------------
Cookie:
http协议的无连接性要求出现一种保存c/s间状态的机制
cookie:保存到客户端的一个文本文件,与特定客户无关
cookie:以"名-值”对的形式保存数据
创建cookie:new cookie(name,value)
可以使用cookie的setxxx方法来设定一些相应的值
setName(String name)/getName()
setValue(String value)/getValue()
setMaxAge(int age)/getAge()
利用httpServletResponse的addCookie(cookie)方法将它设置到客户端
利用httpServletRequest的getCookies()方法来读取客户端的所以Cookie返回一个cookie数组
注:1,服务器可以向客户端写内容
2,只能是文本内容
3,客户端可以阻止服务器写入
4,只能拿自己webapp写入的对象
5,cookie分为两种:属于窗口/子窗口、属于文本
6,一个servlet/jsp设置的cookies能够被同一个路径下面或者子路径下面的servlet/jsp读到
Session: HttpSession session = request.getSession(true);
在某段时间一连串客户端与服务端的"交易"
在jsp/servlet不支持cookie,会通过URL重写来实现,就是将一些额外的数据追加到会话的每个URL末尾,服务器在该标示符与其存储的有关的该回话的数据之间建立管理
如:hello.jsp?jsessionid=1234;
可以通过程序来终止一个会话,如果客户端在一段时间内没有操作,服务器会自动终止会话
通过HttpSession来读写Session
规则:
如果浏览器支持Cookie,创建Session的时候会把Sessionid保存在cookie中
如果不支持cookie,必须自己编程使用url重写的方式实现session
使用方法:response.encodeURL()
-->转码
-->URL后面加入sesionid
Session不像cookie拥有路径访问的问题
同一个application下的servlet/jsp可以共享同一个session,前提是同一个客户端窗口
Application:this.getServletContext();
用于保存整个webApplication的生命周期内都可以访问的数据
在API表现为ServletContext
通过HttpServlet的getServletContext方法可以拿到
通过ServletContext的get/setAttribute方法取得/设置相关属性
---------------------- <a href="http://edu.csdn.net"target="blank">ASP.Net+Android+IOS开发</a>、<a href="http://edu.csdn.net"target="blank">.Net培训</a>、期待与您交流! ----------------------