java 验证码生成和验证

1、java 验证码生成与校验原理:

后台生辰验证码图片,将图片传到前台;
后台在session中保存验证码内容;
前台输入验证码后传到后台在后台取出session保存的验证码进行校验。

2、图片生成(创建图片 + 创建随机数):

生成图片工具类:调用工具类中的getRandcode方法 生成验证码(方法中自动把验证码值存进session中)每次点击图片重新刷新验证码
界面初次加载时,调用getVerify()方法即可。
代码:

public class RandomValidateCodeUtil {
	    public static final String RANDOMCODEKEY= "RANDOMVALIDATECODEKEY";//放到session中的key
	    private String randString = "0123456789";//随机产生只有数字的字符串 private String
	    //private String randString = "ABCDEFGHIJKLMNOPQRSTUVWXYZ";//随机产生只有字母的字符串
	    //private String randString = "0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ";//随机产生数字与字母组合的字符串
	    private int width = 95;// 图片宽
	    private int height = 25;// 图片高
	    private int lineSize = 40;// 干扰线数量
	    private int stringNum = 4;// 随机产生字符数量

	    private static final Logger logger = LoggerFactory.getLogger(RandomValidateCodeUtil.class);

	    private Random random = new Random();

	    /**
	     * 获得字体
	     */
	    private Font getFont() {
	        return new Font("Fixedsys", Font.CENTER_BASELINE, 18);
	    }

	    /**
	     * 获得颜色
	     */
	    private Color getRandColor(int fc, int bc) {
	        if (fc > 255)
	            fc = 255;
	        if (bc > 255)
	            bc = 255;
	        int r = fc + random.nextInt(bc - fc - 16);
	        int g = fc + random.nextInt(bc - fc - 14);
	        int b = fc + random.nextInt(bc - fc - 18);
	        return new Color(r, g, b);
	    }

	    /**
	     * 生成随机图片
	     */
	    public void getRandcode(HttpServletRequest request, HttpServletResponse response) {
	        HttpSession session = request.getSession();
	        // BufferedImage类是具有缓冲区的Image类,Image类是用于描述图像信息的类
	        BufferedImage image = new BufferedImage(width, height, BufferedImage.TYPE_INT_BGR);
	        Graphics g = image.getGraphics();// 产生Image对象的Graphics对象,改对象可以在图像上进行各种绘制操作
	        g.fillRect(0, 0, width, height);//图片大小
	        g.setFont(new Font("Times New Roman", Font.ROMAN_BASELINE, 18));//字体大小
	        g.setColor(getRandColor(110, 133));//字体颜色
	        // 绘制干扰线
	        for (int i = 0; i <= lineSize; i++) {
	            drowLine(g);
	        }
	        // 绘制随机字符
	        String randomString = "";
	        for (int i = 1; i <= stringNum; i++) {
	            randomString = drowString(g, randomString, i);
	        }
	        logger.info(randomString);
	        //将生成的随机字符串保存到session中
	        session.removeAttribute(RANDOMCODEKEY);
	        session.setAttribute(RANDOMCODEKEY, randomString);
	        g.dispose();
	        try {
	            // 将内存中的图片通过流动形式输出到客户端
	            ImageIO.write(image, "JPEG", response.getOutputStream());
	        } catch (Exception e) {
	            logger.error("将内存中的图片通过流动形式输出到客户端失败>>>>   ", e);
	        }

	    }

	    /**
	     * 绘制字符串
	     */
	    private String drowString(Graphics g, String randomString, int i) {
	        g.setFont(getFont());
	        g.setColor(new Color(random.nextInt(101), random.nextInt(111), random
	                .nextInt(121)));
	        String rand = String.valueOf(getRandomString(random.nextInt(randString
	                .length())));
	        randomString += rand;
	        g.translate(random.nextInt(3), random.nextInt(3));
	        g.drawString(rand, 13 * i, 16);
	        return randomString;
	    }

	    /**
	     * 绘制干扰线
	     */
	    private void drowLine(Graphics g) {
	        int x = random.nextInt(width);
	        int y = random.nextInt(height);
	        int xl = random.nextInt(13);
	        int yl = random.nextInt(15);
	        g.drawLine(x, y, x + xl, y + yl);
	    }

	    /**
	     * 获取随机的字符
	     */
	    public String getRandomString(int num) {
	        return String.valueOf(randString.charAt(num));
	    }
	}
	******************************************************************************
	Controller层:
	/**
	 * 生成验证码
	 */
	@RequestMapping(value = "/getVerify")
	public void getVerify(HttpServletRequest request, HttpServletResponse response) {
	    try {
	        response.setContentType("image/jpeg");//设置相应类型,告诉浏览器输出的内容为图片
	        response.setHeader("Pragma", "No-cache");//设置响应头信息,告诉浏览器不要缓存此内容
	        response.setHeader("Cache-Control", "no-cache");
	        response.setDateHeader("Expire", 0);
	        RandomValidateCodeUtil randomValidateCode = new RandomValidateCodeUtil();
	        randomValidateCode.getRandcode(request, response);//输出验证码图片方法
	    } catch (Exception e) {
	        logger.error("获取验证码失败>>>>   ", e);
	    }
	}

	********************************************************************************
	前端html代码:

	<div class="row">
	    <div class="col-xs-6 pull_left">
	        <div class="form-group">
	            <input class="form-control" type="tel" id="verify_input" placeholder="请输入验证码" maxlength="4">
	        </div>
	    </div>
	    <div class="col-xs-6 pull_left">
	        <a href="javascript:void(0);" title="点击更换验证码">
	            <img id="imgVerify" src="" alt="更换验证码" height="36" width="100%" onclick="getVerify(this);">
	        </a>
	    </div>
	</div>


	********************************************************
	//获取验证码
	function getVerify(obj){
	    obj.src = httpurl + "/sys/getVerify?"+Math.random();
	}
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

星空是梦想

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值