private Cookie nameCookie=null;
    private Cookie passCookie=null;
    private Cookie cookieUser;
    private UserDao userDao=new UserDaoImpl();
    public void doGet(HttpServletRequest request, HttpServletResponse response)
            throws ServletException, IOException {
        createCookies(request);
        String value=request.getParameter("oper");
        //点击预登录按钮
        if("pre".equals(value)){
            String name=nameCookie.getValue();
            String pass=passCookie.getValue();
            //判断是否是初始化的值,如果不是存储到request域中
            if(!"1".equals(name)){
                request.setAttribute("name", name);
            }
            if(!"1".equals(pass)){
                request.setAttribute("pass", pass);
            }
            //跳转到登录界面
            request.getRequestDispatcher("/login.jsp").forward(request, response);
        }else if("login".equals(value)){//请求点击登陆按钮  ./login.do?oper=pre操作,获取cookie中的信息
            String name=request.getParameter("name");
            String pass=request.getParameter("pass");
            User user=new User();
            user=userDao.checkLogin(name, pass);
            //验证用户名和密码
            if(user!=null){
                nameCookie.setValue(name);
                passCookie.setValue(pass);
                cookieUser=getCookie(request, "user");
                if(cookieUser==null){
                    cookieUser=new Cookie("user","");
                }
                cookieUser.setValue(user.getId()+"");
                response.addCookie(nameCookie);
                response.addCookie(passCookie);
                response.addCookie(cookieUser);
                request.getRequestDispatcher("./goods_pay.jsp").forward(request, response);
            }else{
                nameCookie.setValue(name);
                passCookie.setValue("1");
                response.addCookie(nameCookie);
                response.addCookie(passCookie);
                request.getRequestDispatcher("/login.do?oper=pre").forward(request, response);
            }
        }else if("delete".equals(value)){
             cookieUser=getCookie(request, "user");
             if(cookieUser!=null){
                 cookieUser=new Cookie("user", null);
                 cookieUser.setMaxAge(0);
                 response.addCookie(cookieUser);
             }
             request.getRequestDispatcher("/init.do").forward(request, response);
        }
    }
    //判断是否已经有了存储 用户名和密码的cookie对象
    private void createCookies(HttpServletRequest request) {
        Cookie[] cookies=request.getCookies();
        if(cookies!=null){
            for(Cookie ck:cookies){
                //获取Cookie名称
                String name=ck.getName();
                if("name".equals(name)){
                    nameCookie=ck;
                }else if("pass".equals(name)){
                    passCookie=ck;
                }
            }
        }
        //如果request中没有cookie对象,创建要存储用户名的cookie对象
        if(nameCookie==null){
            nameCookie=new Cookie("name", "1");
        }
        if(passCookie==null){
            passCookie=new Cookie("pass", "1");
        }
    }

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

private Cookie getCookie(HttpServletRequest request,String cookieName) {
        Cookie cookie = null;
        Cookie[] cookies = request.getCookies();
        if (cookies != null) {
            for (Cookie ck : cookies) {
                String name = ck.getName();
                if (cookieName.equals(name)) {
                    cookie = ck;
                }
            }
        }
        return cookie;
    }

JavaWeb学习记录(六)——用户登录功能之Cookie的更多相关文章

  1. JavaWeb学习记录(十五)——浏览器Cookie禁用后的处理

    IE禁用Cookie方式:

  2. JavaWeb学习记录(六)——用户登录功能

    使用JDBC.spring框架.servlet实现一个简单的用户登录功能. 一.mySql数据库 SET FOREIGN_KEY_CHECKS=0; -- ---------------------- ...

  3. Struts2整合Hibernate3实现用户登录功能

    所用技术:struts2 ,hibernate,jsp,mysql 本DEMO仅仅实现用户登录功能,采用MVC思想,自己也觉得相对是比较简单,比较容易理解数据流向的一个例子,通过整合这个过程,能够清晰 ...

  4. 实现Web上的用户登录功能

    关于如何实现web上的自动登录功能 文章来源http://coolshell.cn/articles/5353.html Web上的用户登录功能应该是最基本的功能了,可是在我看过一些站点的用户登录功能 ...

  5. 你会做Web上的用户登录功能吗?

    Web上的用户登录功能应该是最基本的功能了,可是在我看过一些站点的用户登录功能后,我觉得很有必要写一篇文章教大家怎么来做用户登录功能.下面的文章告诉大家这个功能可能并没有你所想像的那么简单,这是一个关 ...

  6. 利用MYSQL的函数实现用户登录功能,进出都是JSON(第二版)

    利用MYSQL的函数实现用户登录功能,进出都是JSON(第二版) CREATE DEFINER=`root`@`%` FUNCTION `uc_session_login`( `reqjson` JS ...

  7. 使用 Flask 框架写用户登录功能的Demo时碰到的各种坑(一)——创建应用

    使用 Flask 框架写用户登录功能的Demo时碰到的各种坑(一)——创建应用 使用 Flask 框架写用户登录功能的Demo时碰到的各种坑(二)——使用蓝图功能进行模块化 使用 Flask 框架写用 ...

  8. 使用 Flask 框架写用户登录功能的Demo时碰到的各种坑(三)——使用Flask-Login库实现登录功能

    使用 Flask 框架写用户登录功能的Demo时碰到的各种坑(一)——创建应用 使用 Flask 框架写用户登录功能的Demo时碰到的各种坑(二)——使用蓝图功能进行模块化 使用 Flask 框架写用 ...

  9. tail -fn 1000 test.log | grep '关键字' 按照时间段 sed -n '/2014-12-17 16:17:20/,/2014-12-17 16:17:36/p' test.log /var/log/wtmp 该日志文件永久记录每个用户登录、注销及系统的启动、停机的事件

    Linux 6种日志查看方法,不会看日志会被鄙视的 2020-02-11阅读 7.3K0   作为一名后端程序员,和Linux打交道的地方很多,不会看Linux日志,非常容易受到来自同事和面试官的嘲讽 ...

随机推荐

  1. 对项目的测试--Resharper

    初学 这里做个记录. 1:安装后,Resharper会用他自己的英文智能提示,替换掉 vs2010的智能提示,所以我们要换回到vs2010的智能提示 2:快捷键.是使用vs2010的快捷键还是使用 R ...

  2. @ResultMapping注解

    @RequestMapping注解1.url映射放在方法上:@RequestMapping("/itemsEdit")2.窄化url请求映射放在类上,定义根路径,url就变成根路径 ...

  3. 更改layout的布局

    创建了一个layout,缺省都是LinearLayout,原来都在xml把他改成其他布局,习惯了拖放的方式觉得挺麻烦. 其实vs2013有这个功能,就是在设计界面单机右键可以删除布局,然后拖一个布局进 ...

  4. 使用HttpOnly提升Cookie安全性

        在介绍HttpOnly之前,我想跟大家聊聊Cookie及XSS. 随着B/S的普及,我们平时上网都是依赖于http协议完成,而Http是无状态的,即同一个会话的连续两个请求互相不了解,他们由最 ...

  5. (转)Ratchet教程:meta与link标签

    原文:http://www.w3cplus.com/mobile/meta-and-link-tags-for-ratchet.html Ratchet教程:meta与link标签           ...

  6. hdu 2094

    ps: 原本听说用set容器做是最好的...然而我并不懂..就用C语言做了...就是先输入赢得一组和输的一组,然后把重复的删掉,再比较赢得一组里没有出现在输的一组里的人数,如果是1就是YES,其他就是 ...

  7. NSHTTPCookie类详解

    继承自 NSObject的 符合 NSObject的(NSObject的)  框架 /系统/资源库/框架/ Foundation.framework 可用性 安装使用Safari 1.0在Mac OS ...

  8. 【LeetCode OJ】Evaluate Reverse Polish Notation

    Problem link: http://oj.leetcode.com/problems/evaluate-reverse-polish-notation/ According to the wik ...

  9. 进程同步(二)—— 信号量&内存共享

    内存共享是进程间常用的通信方式,可以实现两个完全独立的进程通信. 在访问共享内存时,同时需要信号量进行访问控制. 使用ipcs -m命令可以查看系统共享内存,ipce -m + key 可以删除指定的 ...

  10. HDU 4902 (线段树)

    Problem Nice boat(HDU 4902) 题目大意 维护一个序列,两种操作. 第一种操作,将一段区间[l,r]赋值为x. 第二种操作,将一段区间[l,r]中大于等于x的数与x求gcd. ...