Session 和 Cookie 使用

目录

一、Cookie

1、Cookie的创建

  2、服务器获取Cookie

3、Cookie值的修改

方案一

方案二

4、浏览器查看Cookie

5、Cookie生命控制

 6、Cookie有效路径Path的设置

 7、Cookie免输入用户名登录

二、Session

1、Session

2、创建Session和获取

3、Session域数据的存取

4、Session生命周期控制

 5、浏览器和Session之间关联的技术内幕


一、Cookie

Cookie  是服务器通知客户端保存键值对的一种技术。客户端有了  Cookie  后,每次请求都发送给服务器。每个  Cookie  的大小不能超过  4kb

1、Cookie的创建

Session 和 Cookie 使用_第1张图片

使用BaseServlet抽取Servlet对象,在请求中携带名称为action,值为方法名的参数动态调用请求方法。

public abstract class BaseServlet extends HttpServlet{
    @Override
    protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
        doPost(req,resp);
    }

    @Override
    protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
       //解决请求中文乱码问题
       req.setCharacterEncoding("UTF-8");
       //解决响应中文乱码问题
        resp.setContentType("text/html; charset=UTF-8");

        //获取参数action的值
        String action=req.getParameter("action");

        try {
            // 匹配指定名称和参数的类的方法,此方法返回的是Method对象
            Method method = this.getClass().getDeclaredMethod(action, HttpServletRequest.class, HttpServletResponse.class);
            //调用目标业务方法,这里的 this 是子类
            method.invoke(this,req,resp);
        } catch (Exception e){
            e.printStackTrace();
        }
    }
}

Servlet程序 

public class CookieServlet extends BaseServlet {
    protected void createCookie(HttpServletRequestreq,HttpServletResponse resp)throwsServletException, IOException {
        //1 创建  Cookie对象
        Cookie cookie = new Cookie("key4", "value4"); 

        //2 通知客户端保存  Cookie
        resp.addCookie(cookie);

        resp.getWriter().write("Cookie创建成功");
    }    
}

web.xml

    
        CookieServlet
        com.servlet.CookieServlet
    
    
        CookieServlet
        /cookieServlet
    

请求地址:localhost:8080/13_cookie_session/cookieServlet?action=createCookie

 解释:当请求到达CookieServlet,由于没有 doGet() 方法,会向父类寻找, BaseServlet中有 doGet()方法,调用父类的 doGet()方法,首先获取 action 的值createCoookie,这里的 this是子类,通过反射调用子类名为 createCookie 的方法。

  2、服务器获取Cookie

Session 和 Cookie 使用_第2张图片

 Cookie的工具类:查找指定名称的  Cookie对象

public class CookieUtils {
    public static Cookie findCookie(String name,Cookie[] cookies){
        if(name==null||cookies==null||cookies.length==0){
            return null;
        }
        for(Cookie cookie : cookies){
            if(name.equals(cookie.getName())){
                return cookie;
            }
        }
        return null;
    }
}
    protected void getCookie(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {

        Cookie[] cookies = req.getCookies();

        for (Cookie cookie : cookies) {
            resp.getWriter().write("Cookie[" + cookie.getName() + "=" + cookie.getValue() + "] 
"); } Cookie iWantCookie = CookieUtils.findCookie("key3", cookies); if (iWantCookie != null) { resp.getWriter().write("找到了需要的Cookie"); } }

3、Cookie值的修改

方案一

    protected void updateCookie(HttpServletRequest req, HttpServletResponse resp) throws ServletExcepton, IOException {
         Cookie cookie = new Cookie("key3","NewValue");
         resp.addCookie(cookie);
    }

方案二

    protected void updateCookie(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
        Cookie cookie1 = CookieUtils.findCookie("key3", req.getCookies());
        if(cookie1!=null){
            cookie1.setValue("newValue2");
            resp.addCookie(cookie1);
        }
    }

4、浏览器查看Cookie

Session 和 Cookie 使用_第3张图片

5、Cookie生命控制

Cookie  的生命控制指的是如何管理  Cookie  什么时候被销毁(删除) 

setMaxAge()

  • 正数,表示在指定的秒数后过期
  • 负数,表示浏览器一关,Cookie  就会被删除(默认值是-1) 
  • 零,表示马上删除  Cookie
    protected void life3600(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {

        Cookie cookie = new Cookie("life3600", "life3600");
        cookie.setMaxAge(60 * 60);
        resp.addCookie(cookie);
        resp.getWriter().write("已经创建了一个存活一小时的 Cookie");
    }

    protected void deleteNow(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
        Cookie cookie = CookieUtils.findCookie("key3", req.getCookies());

        if(cookie!=null){
            cookie.setMaxAge(0);
            resp.addCookie(cookie);
            resp.getWriter().write("key3已删除");
        }
    }

    protected void defaultLife(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {

        Cookie cookie = new Cookie("defalutLife","defaultLife");
        cookie.setMaxAge(-1);//设置存活时间
        resp.addCookie(cookie);
        resp.getWriter().write("默认的会话级别的Cookie");
    }

cookie.html








Cookie
	



	
	

 6、Cookie有效路径Path的设置

Cookie 的 path 属性可以有效的过滤哪些 Cookie 可以发送给服务器。哪些不发。 

path 属性是通过请求的地址来进行有效的过滤。

  • CookieA     path=/工程路径 
  • CookieB     path=/工程路径/abc

请求地址如下:

http://ip:port/工程路径/a.html

  • CookieA   发送 
  • CookieB   不发送

http://ip:port/工程路径/abc/a.html

  • CookieA 发送 
  • CookieB 发送
    protected void testPath(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
        Cookie cookie = new Cookie("path1", "path1");
        // getContextPath() 得到工程路径
        cookie.setPath( req.getContextPath() + "/abc" ); 

        //访问http://localhost:8080/13_cookie_session/abc才能看到该cookie
        resp.addCookie(cookie);

        resp.getWriter().write("创建了一个带有 Path 路径的 Cookie");
    }

 7、Cookie免输入用户名登录

Session 和 Cookie 使用_第4张图片

 login.jsp 页面

用户名:
密码:

LoginServlet 程序

public class LoginServlet extends HttpServlet{
    @Override
    protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
        String username = req.getParameter("username");
        String password = req.getParameter("password");

        if("1".equals(username)&&"1".equals(password)){
            Cookie cookie = new Cookie("username", username);
            cookie.setMaxAge(60*60*24); //当前cookie一天有效
            resp.addCookie(cookie);
            System.out.println("登录成功");
        }else{
            System.out.println("登录失败");
        }
    }
}

二、Session

1、Session

  1. Session 是一个接口(HttpSession)
  2. Session  就是会话。它是用来维护一个客户端和服务器之间关联的一种技术。
  3. 每个客户端都有自己的一个  Session  会话。
  4. Session  会话中,我们经常用来保存用户登录之后的信息。

2、创建Session和获取

request.getSession()

  • 第一次调用是:创建  Session  会话
  • 之后调用都是:获取前面创建好的  Session  会话对象。 

isNew():判断到底是不是刚创建出来的(新的)

  • true    表示刚创建
  • false     表示获取之前创建

每个会话都有一个身份证号。也就是  ID 值。而且这个  ID  是唯一的。 

  • getId()  得到Session  的会话 id 值。
    protected void createOrGetSession(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
        HttpSession session = req.getSession();

        boolean isNew = session.isNew();

        String id = session.getId();

        resp.getWriter().write("得到的session的id是:"+id+"
"); resp.getWriter().write("session是否是新创建的"+isNew+"
"); }

3、Session域数据的存取

public class SessionServlet extends BaseServlet{
    protected void deleteNow(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {

    protected void setAttribute(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
        req.getSession().setAttribute("key1", "value1");
        resp.getWriter().write("已经往 Session 中保存了数据");
    }

    protected void getAttribute(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
        Object attribute = req.getSession().getAttribute("key1");
        resp.getWriter().write("从 Session 中获取出 key1 的数据是:" + attribute);
    }
}

4、Session生命周期控制

/*
    设置Session的超时时间(以秒为单位),超过指定的时长,Session 就会被销毁。
        值为正数的时候,设定 Sessio 的超时时长。 
        负数表示永不超时
*/
public void setMaxInactiveInterval(int interval)   

//获取 Session 的超时时间 
public int getMaxInactiveInterval() 

//让当前 Session 会话马上超时无效。
public void invalidate()      

Session  默认的超时时间长为  30  分钟。

因为在 Tomcat 服务器的配置文件 web.xml 中默认有以下的配置,它就表示配置了当前 Tomcat 服务器下所有的 Session 超时配置默认时长为:30  分钟。


    30 

如果说。你希望你的  web  工程,默认的  Session  的超时时长为其他时长。你可以在你自己的  web.xml  配置文件中做以上相同的配置。就可以修改你的 web 工程所有  Seession  的默认超时时长。

 

    20 

如果你想只修改个别  Session  的超时时长。就可以使用上面的  API。

Session超时的概念介绍

Session 和 Cookie 使用_第5张图片

 

    protected void deleteNow(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
        HttpSession session = req.getSession();
        session.invalidate();
        resp.getWriter().write("Session 已经设置为超时(无效)");
    }

    protected void life3(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {

        HttpSession session = req.getSession();
        session.setMaxInactiveInterval(3);
        resp.getWriter().write("当前 Session 已经设置为 3 秒后超时");
    }

session.html








Session
	



	
	

 

 5、浏览器和Session之间关联的技术内幕

Session  技术,底层其实是基于  Cookie  技术来实现的。

Session 和 Cookie 使用_第6张图片

 

 

你可能感兴趣的:(JavaWeb,java,servlet,session,cookie)