cookie用户自动登录和事件监听机制

 1、

package com.hbsi.csdn.Dao;

import java.util.Arrays;
import java.util.List;

import com.hbsi.csdn.domain.User;

public class UserDao {
 List<User> db = Arrays.asList(new User("aa", "11"), new User("bb", "22"),
   new User("cc", "33"));
 public List<User> getAll(){//查找所有用户
  return db;
 }
 public User find(String username){  //根据用户名查找用户
  for(User user:db){
   if(user.getUsername().equals(username)){
    return user;
   }
  }
  return null;
 }
 public User find(String username,String password){  //核实用户名和密码
  for(User user:db){
   if(user.getUsername().equals(username)&&user.getPassword().equals(password)){
    return user;
   }
  }
  return null;
 }
}

2、

package com.hbsi.csdn.filter;

import java.io.IOException;
import java.security.MessageDigest;

import javax.servlet.Filter;
import javax.servlet.FilterChain;
import javax.servlet.FilterConfig;
import javax.servlet.ServletException;
import javax.servlet.ServletRequest;
import javax.servlet.ServletResponse;
import javax.servlet.http.Cookie;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

import sun.misc.BASE64Encoder;

import com.hbsi.csdn.Dao.UserDao;
import com.hbsi.csdn.domain.User;

public class AutoLoginFilter implements Filter {

 public void doFilter(ServletRequest req, ServletResponse resp,
   FilterChain chain) throws IOException, ServletException {

  HttpServletRequest request = (HttpServletRequest) req;
  HttpServletResponse response = (HttpServletResponse) resp;

  User user = (User) request.getSession().getAttribute("user");

  // 1、检查用户是否登录
  if (user != null) {
   chain.doFilter(request, response);
   return;
  } else {
   // 2、检查用户是否带着自动登录的cookie过来
   Cookie autoLoginCookie = null;
   Cookie cookies[] = request.getCookies();

   for (int i = 0; cookies != null && i < cookies.length; i++) {
    if (cookies[i].getName().equals("autoLogin")) {
     autoLoginCookie = cookies[i];
    }
   }
   if (autoLoginCookie == null) {
    request.setAttribute("message", "用户没有登录,请重新登录");
    request.getRequestDispatcher("/message.jsp").forward(request,
      response);
    chain.doFilter(request, response);
    return;
   } else { // 3、用户带着cookie来了,程序帮助用户完成自动登录
    String value = autoLoginCookie.getValue();// 获取到cookie中的值
    if (value.split("\\:").length != 3) { // 如果cookie的格式不正确
     request.setAttribute("message", "用户没有登录,请重新登录");
     request.getRequestDispatcher("/message.jsp").forward(
       request, response);
     chain.doFilter(request, response);
     return;
    } else {
     String username = value.split("\\:")[0]; // 获取cookie中的各个值
     long expiresTime = Long.parseLong(value.split("\\:")[1]);
     String md5value = value.split("\\:")[2];
     // 4、判断cookie是否在有效期内
     if (expiresTime >= System.currentTimeMillis()) {
      chain.doFilter(request, response);
      return;
     }
     // 5、 如果cookie有效的话,判断用户名和密码。用户名已经获得,找到对应的密码
     UserDao dao = new UserDao();
     user = dao.find(username);
     String password = user.getPassword();
     String server_md5value = md5(username + ":" + expiresTime
       + ":" + password);
     // 6、判断用户登录的密码是否一致
     if (!server_md5value.equals(md5value)) {
      request.setAttribute("message", "用户没有登录,请重新登录");
      request.getRequestDispatcher("/message.jsp").forward(
        request, response);
      chain.doFilter(request, response);
      return;
     }

     request.getSession().setAttribute("user", user);
     chain.doFilter(request, response);

    }

   }

  }
 }

 private String md5(String input) {
  try {
   MessageDigest md = MessageDigest.getInstance("md5");
   byte result[] = md.digest(input.getBytes());
   BASE64Encoder encoder = new BASE64Encoder();
   return encoder.encode(result);

  } catch (Exception e) {
   throw new RuntimeException(e);
  }

 }

 public void init(FilterConfig arg0) throws ServletException {
  // TODO Auto-generated method stub

 }

 public void destroy() {
  // TODO Auto-generated method stub

 }

}

 

3、

package com.hbsi.csdn.servlet;

import java.io.IOException;
import java.io.PrintWriter;
import java.security.MessageDigest;
import java.security.NoSuchAlgorithmException;

import javax.servlet.ServletException;
import javax.servlet.http.Cookie;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

import sun.misc.BASE64Encoder;

import com.hbsi.csdn.Dao.UserDao;
import com.hbsi.csdn.domain.User;

public class LoginServlet extends HttpServlet {

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

 }

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

  String username = request.getParameter("username");
  String password = request.getParameter("password");
  String autoLoginTime1 = request.getParameter("autoLoginTime");

  if (autoLoginTime1 != null) {
   int autoLoginTime = Integer.parseInt(autoLoginTime1);
   UserDao dao = new UserDao();
   User user = dao.find(username, password);
   if (user != null) {
    request.getSession().setAttribute("user", user);
    sendCookie(response, user, autoLoginTime);
    response.sendRedirect("/FilterAutoLogin/index.jsp");
   }else{
    request.setAttribute("message", "用户名或者密码不正确!");
    request.getRequestDispatcher("/message.jsp").forward(request,response);
   }

  }else{
   UserDao dao=new UserDao();
   User user=dao.find(username, password);
   if(user!=null){
    request.getSession().setAttribute("user", user);
    response.sendRedirect("/FilterAutoLogin/index.jsp");
   }else{
    request.setAttribute("message", "用户名或者密码不正确!");
    request.getRequestDispatcher("/message.jsp").forward(request,response);
   }
  }

 }

 private void sendCookie(HttpServletResponse response, User user,
   int autoLoginTime) {
  long time = System.currentTimeMillis() + autoLoginTime;
  String md5value = md5(user.getUsername() + ":" + time + ":"
    + user.getPassword());
  String cookievalue=user.getUsername()+":"+time+":"+md5value;
  Cookie cookie=new Cookie("autoLogin",cookievalue);
  cookie.setMaxAge(autoLoginTime);   //设置cookie的有效时间
  cookie.setPath("/FilterAutoLogin");  //设置cookie的有效范围
  response.addCookie(cookie);  //发送cookie
 }

 private String md5(String input) {
  try {
   MessageDigest md = MessageDigest.getInstance("md5");
   byte result[] = md.digest(input.getBytes());
   BASE64Encoder encoder = new BASE64Encoder();
   return encoder.encode(result);

  } catch (Exception e) {
   throw new RuntimeException(e);
  }

 }

}


 

4、事件:当用户在界面上执行一个操作,例如按下键盘、拖动或者单击鼠标时,都将产生一个事件。Java中事件是用来描述不同类型用户操作的对象,Java中有很多不同类型的事件。例如:单击,双击,右击,拖动,键盘的按下、释放,文本域内容改变等。
 
事件源:产生事件的组件就是一个事件源。例如,当在一个Button上单击鼠标是,将产生一个ActionEvent类型的事件,而这个Button就是事件源
 
事件监听器:就是调用事件处理方法的对象。当界面操作事件产生并被发送到产生事件的组件时,该组件将把事件发送给能接受和处理该事件的监听器。
 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值