java实现验证码校验

大家好,今天给大家带来的是验证码的校验功能实现,在平时总会有一些闲杂人等,会找一些网站进行暴力注册。而验证码就是防止恶意注册的一种方式。今天我就跟大家分享一下。(验证码工具类贴在最下面)
首先在前台导入验证码图片
jsp方式

<label for="img">验证码:</label>

<input type="text" name="verifycode" id="verifycode"/>

<img id="img" src="${pageContext.request.contextPath}/checkCode" title="看不清点击刷新"/>

然后用原生js加一个点击时刷新的效果

 <script type="text/javascript">
 
window.οnlοad=function () {
         document.getElementById("img").οnclick=function () {
              this.src="${pageContext.request.contextPath}/checkCode?time="+new Date().getTime();
   }
}

  </script>

后台Servlet
//获取用户传递的验证码参数和Session中的验证码参数

//用户传递参数

String checkcode=request.getParameter("verifycode");
 HttpSession session=request.getSession();

//Session中的验证码 该参数是通过工具类在Session中赋的参数

String checkcode_server= (String) session.getAttribute("CHECKCODE_SERVER");

//删除session中的验证码,确保验证码的一次性
//参数为工具类中session存储的name值
session.removeAttribute(“CHECKCODE_SERVER”);

//判断验证码

if (checkcode_server==null&&!checkcode_server.equalsIgnoreCase(checkcode)){

//验证码不正确
//提示信息

 request.setAttribute("login_msg","验证码错误!");
//跳转登陆页面
request.getRequestDispatcher("/login.jsp").forward(request,response);
return;
  }

Servlet方式验证

//验证码校验
    String check=request.getParameter("check");
    //从session中获取验证码
    HttpSession session=request.getSession();
    String checkcode_server= (String) session.getAttribute("CHECKCODE_SERVER");
    //保证验证码唯一 参数为工具类中session存储的name值
    session.removeAttribute("CHECKCODE_SERVER");

    //比较
    if (checkcode_server==null||!checkcode_server.equalsIgnoreCase(check)){
        //验证码错误
        ResultInfo info=new ResultInfo();
        //注册失败
        info.setFlag(false);
        info.setErrorMsg("验证码错误!");
        //将info对象序列化为json
        ObjectMapper mapper=new ObjectMapper();
        String json=mapper.writeValueAsString(info);
        response.setContentType("application/json;charset=utf-8");
        response.getWriter().write(json);
        return ;
    }

//验证码工具类
package cn.easyArch.web.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 CheckCodeServlet extends HttpServlet {
    public void doGet(HttpServletRequest request,HttpServletResponse response)throws ServletException, IOException {
    //服务器通知浏览器不要缓存
    response.setHeader(“pragma”,“no-cache”);
    response.setHeader(“cache-control”,“no-cache”);
    response.setHeader(“expires”,“0”);
    //在内存中创建一个长80,宽30的图片,默认黑色背景
    //参数一:长
    //参数二:宽
    //参数三:颜色
    int width = 80;
    int height = 30;
    BufferedImage image = new BufferedImage(width,height, BufferedImage.TYPE_INT_RGB);
    //获取画笔

    Graphics g = image.getGraphics();
    //设置画笔颜色为灰色
    g.setColor(Color.GRAY);
    //填充图片
    g.fillRect(0,0, width,height);
    //产生4个随机验证码,12Ey
    String checkCode = getCheckCode();
    //将验证码放入HttpSession中

request.getSession().setAttribute(“CHECKCODE_SERVER”,checkCode);
//设置画笔颜色为黄色
g.setColor(Color.YELLOW);
//设置字体的小大
g.setFont(new Font(“黑体”, Font.BOLD,24));
//向图片上写入验证码
g.drawString(checkCode,15,25);
//将内存中的图片输出到浏览器
//参数一:图片对象
//参数二:图片的格式,如PNG,JPG,GIF
//参数三:图片输出到哪里去

ImageIO.write(image,“PNG”,response.getOutputStream());
}
/**
* 产生4位随机字符串
*/
private String getCheckCode() {
String base = “0123456789ABCDEFGabcdefg”;
int size = base.length();
Random r = new Random();
StringBuffer sb = new StringBuffer();
for(int i=1;i<=4;i++){
//产生0到size-1的随机值

int index = r.nextInt(size);
//在base字符串中获取下标为index的字符
char c = base.charAt(index);
//将c放入到StringBuffer中去
sb.append©;
}
return sb.toString();
}
public void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
this.doGet(request,response);
}
}

发布了16 篇原创文章 · 获赞 17 · 访问量 1292

猜你喜欢

转载自blog.csdn.net/amazinga/article/details/104334186