cookie和session的代码实现

 1、设置cookie

  今天笔试题考的是cookie的设置,我竟然选了request也可以设置cookie,我的天呀。

  我们来看如何在response设置吧

  1. public void service(HttpServletRequest req,HttpServletResponse resp) throws ServletException,IOException{
  2.  
  3. Cookie c = new Cookie("name","jenkins");
  4. resp.addCookie(c);
  5.  
  6. } 

  这样子设置,实际上是在返回的消息头中加了一个key-value,key为Set-Cookie,value也是key-value的形式,上面的就是:name=jenkins,多个cookie用分号(;)隔开

  消息头中的样式是:Set-Cookie:name=jenkins;JSESSIONID=ERERE23343423

  其实如果要在request中把cookie返回到服务器端,我们可以在请求的消息头中加一个值:

  1. package servletbase;
  2.  
  3. import java.io.IOException;
  4. import java.io.Writer;
  5. import java.util.ArrayList;
  6. import java.util.List;
  7. import javax.servlet.ServletException;
  8. import javax.servlet.http.Cookie;
  9. import javax.servlet.http.HttpServlet;
  10. import javax.servlet.http.HttpServletRequest;
  11. import javax.servlet.http.HttpServletResponse;
  12. import org.apache.commons.httpclient.Header;
  13. import org.apache.commons.httpclient.HttpClient;
  14.  
  15. public class MyServlet01 extends HttpServlet{
  16.  
  17. public void postCookieToServer(){
  18. HttpClient client = new HttpClient();
  19. List<Header> headers = new ArrayList<Header>();
  20. //把key为JSESSIONID的cookie上传到服务器,服务器会根据这个id来判断
  21. //发起该会话的用户是不是之前登录过,做鉴权
  22. headers.add(new Header("cookie","JSESSIONID=RERER3"));
  23.      //设置消息头
  24. client.getHostConfiguration().getParams().setParameter("http.default-headers", headers);
  25. }
  26.  
  27. }

2、查询Cookie

  在请求对象中获取:

  1. public void getCookieFromRequest(HttpServletRequest request){
  2. //获取cookie数组
  3. Cookie[] cookies = request.getCookies();
  4. for(Cookie cookie:cookies){
  5. //获取cookie的key-value
  6. String name = cookie.getName();
  7. String value = cookie.getValue();
  8. }
  9. }

3、修改Cookie 

  1. public void updateCookieFromRequest(HttpServletRequest request,HttpServletResponse response){
  2. //获取cookie数组
  3. Cookie[] cookies = request.getCookies();
  4. for(Cookie cookie:cookies){
  5. //修改cookie的value
  6. String name = cookie.getName();
  7. if(name.equals("city")){
  8. cookie.setValue("guangzhou");
  9. response.addCookie(cookie);
  10. }
  11. }
  12. }

4、Cookie的编解码(value为中文时需要编码,否则访问时会报错)

  1.      //编码
  2. Cookie c = new Cookie("city",URLEncoder.encode("广州","utf-8"));
  3.  
  4. //解码
  5. String value = c.getValue();
  6. value = URLDecoder.decode(value,"utf-8");

5、Cookie的其他方法

  1. //设置生存时间,单位是秒,默认小于零,保存在内存中。等于零是即刻删除
  2. cookie.setMaxAge(30)
  3.  
  4. //设置路径,浏览器访问服务器时只向cookie路径或者子路径发送cookie,以下访问/web/index.html是会发cookie,但访问/myweb/index.html就不会了
  5. cookie.setPath("/web");

6、Cookie的限制

  a、可以被用户限制

  b、保存在浏览器,不安全,敏感数据要进行加密

  c、只能保存少量数据,大约4k左右

  d、个数有限制

  e、只能保存字符串

7、Session定义和工作原理

  简单来说Session就是服务器为每一个访问的浏览器分配的内存空间,它有一个唯一的id,并且会将这个jsessionid以cookie的形式发送到浏览器(服务器调用了getSession()方法才会返回jsessionid到浏览器,并不是每个请求过来都返回),浏览器再次访问时就会把这个jsessionid发送到服务器,服务器就能找到session对象。

  如果浏览器再次访问(请求消息头中带有jessionid)时,服务器能找到对应的sessionid,则服务器不再返回sessionid到浏览器。

8、获取Session 

  1. //参数为true时一定会返回session对象
  2. HttpSession session = request.getSession(true);
  3. //不加参数默认是true
  4. HttpSession session = request.getSession();
  5.  
  6. //参数为false时,则没有sessionid时返回null
  7. //有sessionid,但找不到session对象时也返回null,能找到session对象就返回该对象
  8. HttpSession session = request.getSession(false);

9、使用Session绑定对象

1
2
3
4
5
6
7
8
9
//绑定对象
void session.setAttribute(String name,Object boj);
//获取绑定对象
Object session.getAttribute(String name);
//移除绑定对象
void session.removeAttribute(String name);
 
//删除session对象
session.invalidate();

10、Session超时

服务器会将空闲时间过长的session对象删除以节省内存空间资源,一般是30分钟 

在tomcat的conf/web.xml文件夹设置(单位是分钟):

  <session-config>

    <session-timeout>30</session-timeout>

  </session-config>

通过编程修改:

  void session.setMaxInactiveInterval(int seconds)

11、浏览器禁用cookie后果及解决方法

  浏览器禁用cookie后,session就不能用了,因为jsessionid不能在浏览器保存。

  解决办法:使用URL重写方法解决,就是在重定向时在url中加sessionid参数,就不需要浏览器保存了。看以下的例子,假如登录验证过程了,需要重定向到首页 

  1. if(name.equals("admin") && pwd.equals("admin")){
  2. session.setAttribute("name",name);
  3. //重定向到首页
  4. //response.sendRedirect("index.jsp");
  5.  
  6. //改为,其会在路径后面加上jsessionid,
  7. //System.out.println("url:" + resp.encodeRedirectURL("index.html")); --> url:index.html;jsessionid=4E885D5D87247441F761C96ACA9A7B68
  8. response.sendRedirect( response.encodeRedirectURL("index.jsp"));   
  9. }

  登录之后我们就可以把sessionid保存到页面,访问时把它带上就好了,可以在url后面加上sessionid,如下:

  localhost:8080/testweb/servlet01;jsessionid=4E885D5D87247441F761C96ACA9A7B68

  另外如果在服务器端没有生成session对象,服务器是不会返回sessionid的cookie到浏览器的,即在服务器端要调用request.getSession()

12、Session的优缺点

  优点:

  a、安全(状态保存在服务器端)

  b、能保存的数据类型更多,cookie只能是字符串

  c、能保存更多数据

  缺点:

  session将状态保存在服务器端,占用服务器内存,当用户量过大时,会严重影响服务器性能。

cookie和session的代码实现的更多相关文章

  1. java的会话管理:Cookie和Session

    java的会话管理:Cookie和Session 1.什么是会话 此处的是指客户端(浏览器)和服务端之间的数据传输.例如用户登录,购物车等 会话管理就是管理浏览器客户端和服务端之间会话过程产生的会话数 ...

  2. 【转】Cookie和Session区别和联系详解

    会话(Session)跟踪是Web程序中常用的技术,用来跟踪用户的整个会话.常用的会话跟踪技术是Cookie与Session.Cookie通过在客户端记录信息确定用户身份,Session通过在服务器端 ...

  3. 理解Cookie和Session机制(转)

    目录[-] Cookie机制 什么是Cookie 记录用户访问次数 Cookie的不可跨域名性 Unicode编码:保存中文 BASE64编码:保存二进制图片 设置Cookie的所有属性 Cookie ...

  4. Django实现表单验证、CSRF、cookie和session、缓存、数据库多表操作(双下划綫)

    通常验证用户输入是否合法的话,是前端js和后端共同验证的,这是因为前端js是可以被禁用的,假如被禁用了,那就没法用js实现验证合法与否了,也就是即使用户输入的不合法,但是也没提示,用户也不知道怎么输入 ...

  5. php的cookie和session相同主域名共享

    如何使用chrome查看cookie和session详见另一篇文章,点这里 首先说cookie, $cookieDomain = '.elf.com'; setcookie('elf', 'im el ...

  6. cookie,session原理,以及如何使用chrome查看。

    首先,先补充下chrome浏览器的使用. 1.1.php源码: <?php $cookieDomain = '.elf.com'; setcookie(, '/', $cookieDomain) ...

  7. Django之Form、CSRF、cookie和session

    Django是一个大而全的web框架,为我们提供了很多实用的功能,本文主要介绍Form.CSRF.cookie和session 一.Form 在web页面中form表单是重要的组成部分,为了数据安全和 ...

  8. php COOKIE和SESSION的一些理解

    web服务器是基于http协议的,而http协议是无状态的,导致任意两个请求之间没有联系.但是我们登录网站后,它却能记住我们的身份,这个过程中一定使用了某个标识来区别我们的身份.对于简单数据传输的我们 ...

  9. 关于Cookie和Session的优缺点

    关于Cookie和Session的优缺点 具体来说cookie机制采用的是在客户端保持状态的方案,而session机制采用的是在服务器端保持状态的方案. Cookie的优缺点:优点:极高的扩展性和可用 ...

随机推荐

  1. Js/Ajax中发送HttpPost请求调用WebService

    1) WebService中的方法 [WebService(Namespace = "http://tempuri.org/")] [WebServiceBinding(Confo ...

  2. dedecms后台上传图片附件返回302的问题

    在网上查了资料,验证可行后,在这儿做个备份! 自己解决了,貌似是swfupload在linux环境下session丢失的引起的 解决办法是:在include/userlogin.class.php文件 ...

  3. 软件工程 speedsnail 第二次冲刺2

    20150519 完成任务:划线第二天,能画出一条直黄线: 遇到问题: 问题1 划线的代码和移动的setcontentview冲突,无法同时显示 解决1 没有解决 明日任务: 线与移动共存

  4. js如何将纯数字字符串转换为long型

    1.js如何将纯数字字符串转换为long型? js 中 int的存储位数?最大十进制数表示是多少? 精度http://www.jb51.net/article/59808.htm 整数(不使用小数点或 ...

  5. 第六章Linux的文件权限与目录配置

    一.Linux用户分类 1.Linux用户分为:(文件|目录)所有者(OWN),(同组内的)用户组,其他人; 2.一个天神:root;,几乎能完成任何事.... 二.目录权限的意义 目录的权限和文件的 ...

  6. [php]php数组函数的相关

    1.8.26---list与extract的作用区别extractextract -- 从数组中将变量导入到当前的符号表 说明int extract ( array var_array [, int ...

  7. hdu 4613 Points<计算几何>

    链接:http://acm.hdu.edu.cn/showproblem.php?pid=4613 题意: 判断一个集合中的点能不能由另一个集合中的点,通过平移,旋转,放缩得到~ 思路:先求出集合中的 ...

  8. oracle 11g 表空间使用率

    Oracle数据库表空间使用量查询: select b.file_name 物理文件名,b.tablespace_name 表空间,b.bytes/1024/1024 大小M,(b.bytes-sum ...

  9. Should .close() be put in finally block or not?

    The following are 3 different ways to close a output writer. The first one puts close() method in tr ...

  10. hdu 5199 Gunner

    原题链接:http://acm.hdu.edu.cn/showproblem.php?pid=5199 简单题,stl水之... #include<algorithm> #include& ...