zoukankan      html  css  js  c++  java
  • 利用Cookie保存用户身份信息实现免登录

      1 <%@page import="sun.misc.BASE64Encoder"%>
      2 <%@page import="java.util.Base64.Encoder"%>
      3 <%@page import="java.security.MessageDigest"%>
      4 <%@ page language="java" contentType="text/html; charset=UTF-8"
      5     pageEncoding="UTF-8"%>
      6 <%!
      7     //定义MD5加密的KEY
      8     public static final String KEY = "wooyoohoo@163.com";
      9 %>
     10 <%
     11     //设置请求和响应的编码格式
     12     request.setCharacterEncoding("utf-8");
     13     response.setCharacterEncoding("utf-8");
     14     
     15     //判断用户的行为
     16     String action = request.getParameter("action");
     17     
     18     System.out.println(action);
     19     
     20     if("login".equals(action)){
     21         //登录
     22         String userName = request.getParameter("username");
     23         String pwd = request.getParameter("password");
     24         //获取有效时长
     25         String time = request.getParameter("time");
     26         
     27         if(userName!=null && !userName.isEmpty()){
     28             MessageDigest digest = MessageDigest.getInstance("MD5");
     29             //将用户名称+KEY进行MD5加密
     30             String encodeStr = new BASE64Encoder().encode(digest.digest((userName+KEY).getBytes("utf-8")));
     31             //保存用户名称
     32             Cookie userNameCookie = new Cookie("username",userName);
     33             Cookie encodeCookie = new Cookie("ssid",encodeStr);
     34             
     35             //设置有效期
     36             userNameCookie.setMaxAge(Integer.parseInt(time));
     37             encodeCookie.setMaxAge(Integer.parseInt(time));
     38             
     39             //设置Cookie
     40             response.addCookie(userNameCookie);
     41             response.addCookie(encodeCookie);
     42             
     43             //重新访问该页面(添加参数System.currentTimeMillis()禁止浏览器缓存页面内容)------------->此处重新请求该页面是为了在一个页面中处理完毕所有逻辑
     44             response.sendRedirect(request.getRequestURI()+"?"+System.currentTimeMillis());
     45             return;
     46         }
     47     }else if("logout".equals(action)){
     48         //退出[清除userNameCookie和encodeCookie]
     49         Cookie userNameCookie = new Cookie("username","");
     50         Cookie encodeCookie = new Cookie("ssid","");
     51         
     52         userNameCookie.setMaxAge(0);
     53         encodeCookie.setMaxAge(0);
     54         
     55         response.addCookie(userNameCookie);
     56         response.addCookie(encodeCookie);
     57         
     58         //重新访问该页面(添加参数System.currentTimeMillis()禁止浏览器缓存页面内容)------------->此处重新请求该页面是为了在一个页面中处理完毕所有逻辑
     59         response.sendRedirect(request.getRequestURI()+"?"+System.currentTimeMillis());
     60         return;
     61     }
     62     
     63     String account = null;
     64     String ssid = null;
     65     
     66     boolean isLogin = false;
     67     
     68     //获取Cookie信息
     69     Cookie[] cookies = request.getCookies();
     70     if(cookies!=null && cookies.length>0){
     71         //判断用户信息
     72         for(int i=0;i<cookies.length;i++){
     73             if(cookies[i].getName().equals("username")){
     74                 //获取账号
     75                 account = cookies[i].getValue();
     76             }else if(cookies[i].getName().equals("ssid")){
     77                 //获取账号和KEY加密后的字符串
     78                 ssid = cookies[i].getValue();
     79             }
     80         }
     81     }
     82     
     83     if(account!=null && ssid!=null){
     84         System.out.println(account);
     85         String getSSID = new BASE64Encoder().encode(MessageDigest.getInstance("MD5").digest((account+KEY).getBytes("utf-8")));
     86         System.out.println(getSSID);
     87         System.out.println(ssid);
     88         if(getSSID.equals(ssid)){
     89             isLogin = true;
     90         }
     91     }
     92 %>
     93 <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
     94 <html>
     95 <head>
     96 <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
     97 <title>利用Cookie实现永久登录</title>
     98 </head>
     99 <body>
    100     <% 
    101         if(isLogin){
    102             %>
    103                 <!-- 显示登陆后的信息 -->
    104                 <span>欢迎回来<% out.print(account);%></span><button onclick="javascript:{window.location.href='<%=request.getRequestURI()%>?action=logout'}">注销</button>
    105             <%
    106         }else{
    107             %>
    108                 <!-- 显示登录界面进行登录操作 -->
    109                 <form action="<%=request.getRequestURI()%>?action=login" method="post">
    110                     账号:&nbsp;<input type="text" name="username"><br>
    111                     密码:<input type="password" name="password">
    112                     <br>
    113                     <input type="radio" value="<%=30*60 %>" name="time">30分钟有效<br>
    114                     <input type="radio" value="<%=7*24*60*60 %>" name="time">7天有效<br>
    115                     <input type="radio" value="<%=30*24*60*60 %>" name="time">30天有效<br>
    116                     <input type="submit" value="登录">
    117                 </form>
    118             <%
    119         }
    120     %>
    121 </body>
    122 </html>
  • 相关阅读:
    37个绝对不容错过的HTML5教程和资源
    Google的自动驾驶汽车无事故成功完成30万英里的驾驶路程
    一个基于jQuery Mobile的移动设备实时幻灯javascript类库 taciónJS
    推荐免费黑色UI工具包下载
    分享一些前端开发人员必备的工具,脚本和资源
    使用HTML5画布实现的超棒javascript动画仪表板:gauge.js
    Google(谷歌)将打算在搜索结果中展示Gmail内容
    免费资源下载:30个用户界面工具栏图标设计
    一张超诡异的HTML图片“松鼠” 是图片同时也是web页面
    带给你设计灵感的30个超棒的暗色系网站设计
  • 原文地址:https://www.cnblogs.com/wooyoohoo/p/9487354.html
Copyright © 2011-2022 走看看