spring boot实现验证码功能

1.建立工具类,配置验证码相关参数

import java.awt.Color;    
import java.awt.Font;    
import java.awt.Graphics;    
import java.awt.image.BufferedImage;    
import java.util.Random;    
 
    
/**  
 * @author ld  
 * @date 2017年11月6日  
 * @param   
 * @desc 图形验证码生成  
 *   
 */       
public class VerifyUtil {    
    // 验证码字符集      
        private static final char[] chars = {       
            '0', '1', '2', '3', '4', '5', '6', '7', '8', '9',       
            'a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i', 'j', 'k', 'l', 'm', 'n',      
            'o', 'p', 'q', 'r', 's', 't', 'u', 'v', 'w', 'x', 'y', 'z',      
            'A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J', 'K', 'L', 'M', 'N',       
            'O', 'P', 'Q', 'R', 'S', 'T', 'U', 'V', 'W', 'X', 'Y', 'Z'};      
        // 字符数量      
        private static final int SIZE = 4;      
        // 干扰线数量      
        private static final int LINES = 5;      
        // 宽度      
        private static final int WIDTH = 80;      
        // 高度      
        private static final int HEIGHT = 40;      
        // 字体大小      
        private static final int FONT_SIZE = 30;      
    
        /**   
         * 生成随机验证码及图片   
         * Object[0]:验证码字符串;   
         * Object[1]:验证码图片。   
         */      
        public static Object[] createImage() {      
            StringBuffer sb = new StringBuffer();      
            // 1.创建空白图片      
            BufferedImage image = new BufferedImage(      
                    WIDTH, HEIGHT, BufferedImage.TYPE_INT_RGB);      
            // 2.获取图片画笔      
            Graphics graphic = image.getGraphics();      
            // 3.设置画笔颜色      
            graphic.setColor(Color.LIGHT_GRAY);      
            // 4.绘制矩形背景      
            graphic.fillRect(0, 0, WIDTH, HEIGHT);      
            // 5.画随机字符      
            Random ran = new Random();      
            for (int i = 0; i <SIZE; i++) {      
                // 取随机字符索引      
                int n = ran.nextInt(chars.length);      
                // 设置随机颜色      
                graphic.setColor(getRandomColor());      
                // 设置字体大小      
                graphic.setFont(new Font(      
                        null, Font.BOLD + Font.ITALIC, FONT_SIZE));      
                // 画字符      
                graphic.drawString(      
                        chars[n] + "", i * WIDTH / SIZE, HEIGHT*2/3);      
                // 记录字符      
                sb.append(chars[n]);      
            }      
            // 6.画干扰线      
            for (int i = 0; i < LINES; i++) {      
                // 设置随机颜色      
                graphic.setColor(getRandomColor());      
                // 随机画线      
                graphic.drawLine(ran.nextInt(WIDTH), ran.nextInt(HEIGHT),      
                        ran.nextInt(WIDTH), ran.nextInt(HEIGHT));      
            }      
            // 7.返回验证码和图片      
            return new Object[]{sb.toString(), image};      
        }      
    
        /**   
         * 随机取色   
         */      
        public static Color getRandomColor() {      
            Random ran = new Random();      
            Color color = new Color(ran.nextInt(256),       
                    ran.nextInt(256), ran.nextInt(256));      
            return color;      
        }      
    
}

2.接口

 @RequestMapping(value="/createValicode",method=RequestMethod.GET)    
	    public void valicode(HttpServletResponse response,HttpSession session) throws Exception{      
	        //利用图片工具生成图片      
	        //第一个参数是生成的验证码,第二个参数是生成的图片      
	        Object[] objs = VerifyUtil.createImage();      
	        //将验证码存入Session      
	        session.setAttribute("imageCode",objs[0]);     
	            
	        //将图片输出给浏览器      
	        BufferedImage image = (BufferedImage) objs[1];      
	        response.setContentType("image/png");      
	        OutputStream os = response.getOutputStream();      
	        ImageIO.write(image, "png", os);    
	    }   

3.测试页面调用

<!DOCTYPE html>  
<html>  
<head lang="en">  
    <meta charset="UTF-8" />  
    <title>hello</title>  
</head>  
<body>  
    <h1 th:text="${info}" />  
    <div>  
        <!-- <img alt="这是图片" src="/img/001.png"/> -->  
        <img alt="验证码" onclick = "this.src='/iot-frame/createValicode?' + Math.floor(Math.random() * 100)" src="/iot-frame/createValicode" />  
    </div>  
    <form action="imgvrifyControllerDefaultKaptcha">  
        <input type="text" name="vrifyCode" />  
        <input type="submit" value="提交"></input>  
    </form>  
</body>  
</html>

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 3
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值