首页 > 其他 > 详细

设计验证码

时间:2020-04-02 20:46:41      阅读:71      评论:0      收藏:0      [点我收藏+]

生成验证码类:

package com.web;

import java.awt.Color;
import java.awt.Font;
import java.awt.Graphics;
import java.awt.image.BufferedImage;
import java.io.IOException;
import java.util.Random;

import javax.imageio.ImageIO;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;

@Controller
public class yzmController {

    @RequestMapping("/yzmImage.do")
    public void yzmImage(HttpServletRequest request,HttpServletResponse response) throws 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", checkCode);
 
        //设置画笔颜色为黄色,字体的小大,并向图片上写入验证码
        g.setColor(Color.RED);
        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 = "0123456789";
        int size = base.length();
        Random r = new Random();
        StringBuilder sb = new StringBuilder();
        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(c);
        }
        return sb.toString();
    }
     
}

jsp 页面:

<div class="form-group col-sm-6">
                                <label class="col-sm-4 control-label">验证码:</label>
                                <div class="col-sm-8">
                                    <img id="checkImg" class="login-icon-yzm" src="<%=webRoot %>/yzmImage.do?codeType=checkCode" onClick="picReload(this)">
                                    <input type="text" class="form-control"  id="imgCheck" placeholder="请输入验证码">
                                    <span id = "img" class="help-block2" style = "display : none;">&nbsp&nbsp请正确输入验证码</span>
                                </div>
                            </div>
                            

js 点击刷新 和 点击提交后自动刷新

//点击刷新验证码
function picReload(img) {    
    img.setAttribute(‘src‘, webRoot
            + ‘/yzmImage.do?codeType=checkCode & a=‘
             + Math.random());
}

自动刷新:
$("#checkImg").click();

后台校验:

String yzm = request.getParameter("useryzm").trim();//用户输入
String sessionCode=request.getSession().getAttribute("checkCode")+"";//系统生成

            if (!yzm.equalsIgnoreCase(sessionCode)){

}

 

设计验证码

原文:https://www.cnblogs.com/lifan12589/p/12622030.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!