Java验证码登陆实现过程

pom.xml中加入如下依赖

<dependency>
	<groupId>com.github.axet</groupId>
	<artifactId>kaptcha</artifactId>
	<version>0.0.9</version>
</dependency>

返回图片的服务

@GetMapping("captcha.jpg")
public void captcha(HttpServletResponse response, HttpSession session)throws ServletException, IOException {
	response.setHeader("Cache-Control", "no-store, no-cache");
	response.setContentType("image/jpeg");

	// 生成文字验证码
	// com.google.code.kaptcha.Producer;
	String text = producer.createText();
	// 生成图片验证码
	BufferedImage image = producer.createImage(text);
	// 将文字保存到session
	session.setAttribute(Constants.KAPTCHA_SESSION_KEY, text);
	ServletOutputStream out = response.getOutputStream();
	ImageIO.write(image, "jpg", out);
}

前端图片显示

<div class="form-group">
	<img alt="如果看不清楚,请单击图片刷新!" class="pointer" src="" id="captcha_img">
	&nbsp;&nbsp;&nbsp;&nbsp;<a href="javascript:;" id="refreshCode">点击刷新</a>
</div>
var page = {
    init: function(){
        var imgsrc = "http://127.0.0.1/user/captcha.jpg";
        $('#captcha_img').attr('src',imgsrc);
        this.bindEvent();
    },
    bindEvent : function(){
        var _this = this;
        $('#refreshCode').click(function(){
            var imgsrc = "http://127.0.0.1/user/captcha.jpg";
            $('#captcha_img').attr('src',imgsrc);
        })
    }
};
$(function(){
    page.init();
});

登陆进行校验

@PostMapping("login")
public String login(String username, String password,
									String captcha, HttpSession session) {
	
	// username,password,captcha都是前端传过来的文本框内容
	Object kaptcha = session.getAttribute(Constants.KAPTCHA_SESSION_KEY);
	if (null == kaptcha) {
		return "验证码过期"
	}
	if (!captcha.equalsIgnoreCase(kaptcha.toString())) {
		return "验证码错误"
	}

	// 这里加你登陆的逻辑
	
	return "验证码正确";
}

效果展示

在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

Java识堂

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

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

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

打赏作者

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

抵扣说明:

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

余额充值