java实现登陆ssm框架_Java使用SSM框架实现登录页面的验证码功能

最终效果展示:

359f4915a86b31838acff08228a6e71e.png

代码展示:

1、前端登录页面代码展示

0abc0f0f8472ba00960a12a7603dec2c.gif

getVerifyCode

0955598c941c335840bca697c289cd5b.gif

/*点击图片更换验证码事件*/

function changeImage() {

$('#verifyCodeImage').attr('src', '${pageContext.request.contextPath }/user/getVerifyCode);

}

2、点击登录之后进行controller代码展示

//验证码验证思路,其实就是后台生成一个随机数保存到session中并且显示到页面,用户输入的验证码与session中保存的随机数进行忽略大小写的比较,如果相同就验证成功,否则失败。

6fd9b17ba3757d4e2b03e082ba6d4323.gif

/* 获取校验码 */

@RequestMapping("/getVerifyCode")

public void generate(HttpServletResponse response, HttpSession session) {

ByteArrayOutputStream output = new ByteArrayOutputStream();

String verifyCodeValue = drawImg(output);

// 将校验码保存到session中

session.setAttribute("verifyCodeValue", verifyCodeValue);

try {

ServletOutputStream out = response.getOutputStream();

output.writeTo(out);

} catch (IOException e) {

logger.info("");

e.printStackTrace();

}

}

/* 绘制验证码 */

private String drawImg(ByteArrayOutputStream output) {

String code = "";

// 随机产生4个字符

for (int i = 0; i < 4; i++) {

code += randomChar();

}

int width = 70;

int height = 25;

BufferedImage bi = new BufferedImage(width, height,

BufferedImage.TYPE_3BYTE_BGR);

Font font = new Font("Times New Roman", Font.PLAIN, 20);

// 调用Graphics2D绘画验证码

Graphics2D g = bi.createGraphics();

g.setFont(font);

Color color = new Color(66, 2, 82);

g.setColor(color);

g.setBackground(new Color(226, 226, 240));

g.clearRect(0, 0, width, height);

FontRenderContext context = g.getFontRenderContext();

Rectangle2D bounds = font.getStringBounds(code, context);

double x = (width - bounds.getWidth()) / 2;

double y = (height - bounds.getHeight()) / 2;

double ascent = bounds.getY();

double baseY = y - ascent;

g.drawString(code, (int) x, (int) baseY);

g.dispose();

try {

ImageIO.write(bi, "jpg", output);

} catch (IOException e) {

e.printStackTrace();

}

return code;

}

/* 获取随机参数 */

private char randomChar() {

Random r = new Random();

String s = "ABCDEFGHJKLMNPRSTUVWXYZ0123456789";

return s.charAt(r.nextInt(s.length()));

}

6bf3d79506a0098f9428d8df21134a61.gif

6c4efe27b45da4cad9298fe8db460d6d.gif

//这段代码放到你的登录请求中,获取用户输入的校验码并进行比较

String verifyCode = request.getParameter("verifyCode");

String sessionVerifyCode = (String) session.getAttribute("verifyCodeValue");

if (!verifyCode.equalsIgnoreCase(sessionVerifyCode)) {

logger.info("");

redirectAttributes.addFlashAttribute("message", "验证码输入有误!");

return "redirect:/user/login";

}

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值