Java Session验证码案例代码实例解析

 更新时间:2020年06月28日 10:51:37   作者:归子莫  
这篇文章主要介绍了Java Session验证码案例代码实例解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下

案例

用户输入用户名,密码以及验证码。

如果用户名和密码输入有误,跳转登录页面,提示:用户名或密码错误

如果验证码输入有误,跳转登录页面,提示:验证码错误

如果全部输入正确,则跳转到主页success.jsp,显示:用户名,欢迎您思路

在生成验证码的时候将它的值存入到session中,在比对的时候再取出来进行对比

代码index.jsp

<%--
 Created by IntelliJ IDEA.
 User: tanglei
 Date: 2020/6/26
 Time: 下午12:48
 To change this template use File | Settings | File Templates.
--%>
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
  <title>login</title>


  <script>
    window.onload = function(){
      document.getElementById("img").onclick = function(){
        this.src="/login_time_war_exploded/checkCode?time="+new Date().getTime();
      }
    }


  </script>
  <style>
    div{
      color: red;
    }

  </style>
</head>
<body>

<form action="/login_time_war_exploded/login" method="post">
  <table>
    <tr>
      <td>用户名</td>
      <td><input type="text" name="username"></td>
    </tr>
    <tr>
      <td>密码</td>
      <td><input type="password" name="password"></td>
    </tr>
    <tr>
      <td>验证码</td>
      <td><input type="text" name="checkCode"></td>
    </tr>
    <tr>
      <td colspan="2"><img id="img" src="/login_time_war_exploded/checkCode"></td>
    </tr>
    <tr>
      <td colspan="2"><input type="submit" value="登录"></td>
    </tr>
  </table>


</form>


<div><%=request.getAttribute("cc_error") == null ? "" : request.getAttribute("cc_error")%></div>
<div><%=request.getAttribute("login_error") == null ? "" : request.getAttribute("login_error") %></div>

</body>
</html>

 success.jsp

<%--
 Created by IntelliJ IDEA.
 User: tanglei
 Date: 2020/6/26
 Time: 下午6:27
 To change this template use File | Settings | File Templates.
--%>
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
  <title>Title</title>
</head>
<body>
<h1><%=request.getSession().getAttribute("user")%>,欢迎您</h1>
</body>
</html>

验证码checkCode.java

package cn.guizimo.servlet;

import javax.imageio.ImageIO;
import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.awt.*;
import java.awt.image.BufferedImage;
import java.io.IOException;
import java.util.Random;

@WebServlet("/checkCode")
public class CheckCode extends HttpServlet {
  @Override
  protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
    int width = 100;
    int height = 50;
    //创建图片对象
    BufferedImage image = new BufferedImage(width, height, BufferedImage.TYPE_INT_BGR);

    //美化
    Graphics g = image.getGraphics();
    //背景
    g.setColor(Color.PINK);
    g.fillRect(0, 0, width, height);
    //边框
    g.setColor(Color.BLUE);
    g.drawRect(0, 0, width - 1, height - 1);

    String str = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789";
    Random ran = new Random();
    StringBuilder sb = new StringBuilder();
    for (int i = 1; i <= 4; i++) {
      int index = ran.nextInt(str.length());
      char ch = str.charAt(index);
      sb.append(ch);
      g.drawString(ch+"",width/5*i,height/2);
    }
    String checkCode_session = sb.toString();
    //将验证码存入session
    req.getSession().setAttribute("checkCode_session",checkCode_session);

    //干扰线
    g.setColor(Color.GREEN);
    for (int i = 0; i < 10; i++) {
      int x1 = ran.nextInt(width);
      int x2= ran.nextInt(width);
      int y1 = ran.nextInt(height);
      int y2 = ran.nextInt(height);
      g.drawLine(x1,y1,x2,y2);
    }


  //输出图片到浏览器
    ImageIO.write(image, "jpg", resp.getOutputStream());

  }

  @Override
  protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
    this.doPost(req, resp);
  }
}

login.java

package cn.guizimo.servlet;

import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession;
import java.io.IOException;

@WebServlet("/login")
public class Login extends HttpServlet {
  @Override
  protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
    //1.设置request编码
    req.setCharacterEncoding("utf-8");
    //2.获取参数
    String username = req.getParameter("username");
    String password = req.getParameter("password");
    String checkCode = req.getParameter("checkCode");
    //3.先获取生成的验证码
    HttpSession session = req.getSession();
    String checkCode_session = (String) session.getAttribute("checkCode_session");
    //删除session中存储的验证码
    //session.removeAttribute("checkCode_session");
    //3.先判断验证码是否正确
    if(checkCode_session!= null && checkCode_session.equalsIgnoreCase(checkCode)){
      //忽略大小写比较
      //验证码正确
      //判断用户名和密码是否一致
      if("zhangsan".equals(username) && "123".equals(password)){//需要调用UserDao查询数据库
        //登录成功
        //存储信息,用户信息
        session.setAttribute("user",username);
        //重定向到success.jsp
        resp.sendRedirect(req.getContextPath()+"/success.jsp");
      }else{
        //登录失败
        //存储提示信息到request
        req.setAttribute("login_error","用户名或密码错误");
        //转发到登录页面
        req.getRequestDispatcher("/login.jsp").forward(req,resp);
      }


    }else{
      //验证码不一致
      //存储提示信息到request
      req.setAttribute("cc_error","验证码错误");
      //转发到登录页面
      req.getRequestDispatcher("/login.jsp").forward(req,resp);

    }
  }

  @Override
  protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
    this.doPost(req, resp);
  }
}

测试登录界面

验证码错误

用户名密码错误

登录成功

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

相关文章

  • jquery uploadify和apache Fileupload实现异步上传文件示例

    jquery uploadify和apache Fileupload实现异步上传文件示例

    这篇文章主要介绍了jquery uploadify和apache Fileupload实现异步上传文件示例,需要的朋友可以参考下
    2014-05-05
  • 解析Java线程同步锁的选择方法

    解析Java线程同步锁的选择方法

    本篇文章是对Java线程同步锁的选择方法进行了详细的分析介绍,需要的朋友参考下
    2013-05-05
  • JetBrains 产品输入激活码 Key is invalid 完美解决方案

    JetBrains 产品输入激活码 Key is invalid 完美解决方案

    JetBrains 系列产品(IDEA、Pycharm 等)使用本站破解教程 (opens new window),在输入激活码时,部分小伙伴反应说提示 Key is invalid 无法激活,今天小编给大家分享完美解决方案,感兴趣的朋友跟随小编一起看看吧
    2022-11-11
  • Java编程伪共享与缓存行填充

    Java编程伪共享与缓存行填充

    这篇文章主要介绍了Java编程伪共享与缓存行填充,下面文章Disruptor提到的CPU缓存话题,做了一些尝试和研究,如Disruptor所说,CPU有缓存伪共享的问题,并且通过缓存行填充能完美的解决这个问题,需要的朋友可以参考一下
    2021-09-09
  • Java基于NIO实现群聊系统

    Java基于NIO实现群聊系统

    这篇文章主要为大家详细介绍了Java基于NIO实现群聊系统,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-11-11
  • 一篇文章带你入门Java多线程

    一篇文章带你入门Java多线程

    这篇文章主要介绍了java多线程编程实例,分享了几则多线程的实例代码,具有一定参考价值,加深多线程编程的理解还是很有帮助的,需要的朋友可以参考下
    2021-08-08
  • 利用Java+Selenium+OpenCV模拟实现网页滑动验证

    利用Java+Selenium+OpenCV模拟实现网页滑动验证

    目前很多网页都有滑动验证,目的就是防止不良爬虫扒他们网站的数据。本文将介绍通过Java Selenium OpenCV解决网页滑块验证,需要的可以参考一下
    2022-01-01
  • Java日常练习题,每天进步一点点(2)

    Java日常练习题,每天进步一点点(2)

    下面小编就为大家带来一篇Java基础的几道练习题(分享)。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧,希望可以帮到你
    2021-07-07
  • Java并发框架:Executor API详解

    Java并发框架:Executor API详解

    这篇文章主要介绍了Java并发框架:Executor API详解,随着当今处理器中可用的核心数量的增加, 随着对实现更高吞吐量的需求的不断增长,多线程 API 变得非常流行。 Java 提供了自己的多线程框架,称为 Executor 框架,需要的朋友可以参考下
    2019-07-07
  • 浅谈SpringBoot中properties、yml、yaml的优先级

    浅谈SpringBoot中properties、yml、yaml的优先级

    优先级低的配置会被先加载,所以优先级高的配置会覆盖优先级低的配置,本文就来介绍一下SpringBoot中properties、yml、yaml的优先级,感兴趣的可以了解一下
    2023-08-08

最新评论