首页 > 代码库 > cookie的基础以及小案例

cookie的基础以及小案例

1.会话技术

  

用户打开一个浏览器访问页面,访问网站的很多页面,访问完成后将浏览器关闭的过程称为是一次会话
cookie:将数据保存到客户端浏览器
session:将数据保存到服务器端

向浏览器保存数据:
response.addCookie(Cookie cookie)
获取浏览器带过来的数据:
request.getCookies();
创建cookie对象:
cookie(String name,String value);

2.JSP的简单概述

jsp:java代码+html的元素+jsp内置的东西
jsp的执行过程:
jsp会被翻译成servlet,编译成class进行执行
jsp的脚本元素:
<%! %>:翻译成类中的成员部分,定义变量,定义方法,定义类,Servlet是线程不安全的,尽量少在类中定义成员变量
<% %>:翻译成类的service方法内部的内容,定义变量,定义类,直接写代码块
<%= %>:翻译成service方法内部的out.print();

3.记录用户的上次登录访问时间

public class ServletDemo1 extends HttpServlet {
    private static final long serialVersionUID = 1L;

    protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        //获取当前时间
        String time = new Date().toLocaleString();
        //获得所有cookie
        Cookie[] cookies = request.getCookies();
        //遍历cookies判断有没有记录登录时间的cookie
        if(cookies != null) {
            for (Cookie cookie : cookies) {
                //如果匹配到保存时间的cookie,用户不是第一次访问
                if(cookie.getName().equals("visitTime")) {
                    String visitTime = cookie.getValue();
                    response.getWriter().write("欢迎回来,上次访问的时间是:"+cookie.getValue());
                }
            }
        }else {
            response.getWriter().write("欢迎访问本网站!");
        }
        //创建cookie对象保存
        Cookie c = new Cookie("visitTime", time);
        //发送cookie
        response.addCookie(c);
    }
    protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        doGet(request, response);
    }

}

4.cookie常用的api

getName();获得名字
getValue();获得对应的值
setDomain(String domain);设置cookie的有效域名
setPath(String path);设置cookie的有效路径
setMaxAge(int maxAge);设置cookie的有效时间

5.cookie的分类

会话级别的cookie:默认的cookie,关闭浏览器cookie就会销毁
持久级别的cookie:可以设置cookie的有效时间,那么关闭浏览器cookie还会存在,手动销毁持久性Cookie.setMaxAge(0);

6.商品的浏览历史记录

步骤:
点击某个商品,将商品ID传递给一个Servlet
在Servlet中判断是否是第一次浏览商品
如果是第一次:将商品ID存入到cookie中
如果不是,判断商品是否被浏览过,如果浏览过,就 删除对应的cookie,添加到首尾,没有就判断是否达到浏览商品显示的最大值,
如果没有就直接添加到第一个,如果达到了就删除最后一个,再添加都首位

public class ServletDemo2 extends HttpServlet {
    private static final long serialVersionUID = 1L;

    protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        //接收用户点击商品传递过来的id
        String id = request.getParameter("id");
        //获得所有的cookie信息
        Cookie[] cookies = request.getCookies();
        //判断有没有浏览过这个商品
        Cookie cookie = CookieUtils.findCookie(cookies,id);
        //用户是第一次浏览
        if(cookie == null) {
            //创建cookie对象
            Cookie c = new Cookie("history", id);
            //设置一个小时的销毁
            cookie.setMaxAge(60*60);
            //发送cookie
            response.addCookie(c);
            //用户不是第一次浏览
        }else {
            //得打cookie的值
            String value =http://www.mamicode.com/ cookie.getValue();
            //切掉在拼接cookie时的,号
            String[] ids = value.split(",");
            //将数组转换成集合
            List<String> aslist = Arrays.asList(ids);
            //将list转换成linkedlist
            LinkedList<String> list = new LinkedList<>(aslist);
            //如果用户之前浏览过这个商品
            if(list.contains(id)) {
                //删除对应的
                list.remove(id);
                list.addFirst(id);
                //没有浏览过
            }else {
                //判断是否达到最大值
                if(list.size() < 3) {
                    //直接添加到第一个
                    list.addFirst(id);
                    //达到最大值
                }else {
                    //删除最后一个
                    list.removeLast();
                    list.addFirst(id);
                }
            }
            //创建拼接的StringBuffer
            StringBuffer sb = new StringBuffer();
            for(String s:list) {
                sb.append(s).append(",");
            }
            //去掉最后一个,号
            String idValue = http://www.mamicode.com/sb.toString().substring(0,sb.length()-1);
            //保存到cookie中
            Cookie c = new Cookie("history", idValue);
            //发送
            response.addCookie(c);
        }
    }

    protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        doGet(request, response);
    }

}
class CookieUtils {

    public static Cookie findCookie(Cookie[] cookies,String name){
        if(cookies == null){
            return null;
        }else{
            for(Cookie cookie:cookies){
                if(name.equals(cookie.getName())){
                    return cookie;
                }
            }
            
            return null;
        }
    }
}

7.清空浏览历史记录

点击清空浏览历史记录的超链接,
跳转到servlet
得到指定保存浏览历史记录的cookie,
设置保存时间为0
重定向到商品显示页面

public class Demo3Servlet extends HttpServlet {
    private static final long serialVersionUID = 1L;

    protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        //获得所有的cookie
        Cookie[] cookies = request.getCookies();
        //遍历cookies,拿到保存浏览历史记录的cookie
        for (Cookie cookie : cookies) {
            if(cookie.getName().equals("history")) {
                //设置保存时间为0
                cookie.setMaxAge(0);
            }
        }
        //重定向
        response.sendRedirect(request.getContextPath()+"/list.jsp");
    }

    protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        doGet(request, response);
    }

}

 

cookie的基础以及小案例