评论

收藏

[Java] SSM 实现登录验证码功能

编程语言 编程语言 发布于:2021-10-06 18:50 | 阅读数:370 | 评论:0

这篇文章主要介绍了SSM 实现登录验证码功能,本文通过实例代码给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下
如果想用框架来实现验证码,可以看我的另外一篇:
kaptcha 框架的使用很简单的。新手必备。
https://www.codeae.com/thread-21959-1-1.html
一、效果图
DSC0000.png

二、实现代码
第一步:先建一个 randomvalidatecode.java 作为工具类。把下面的代码直接复制粘贴即可。
package com.utils;
import java.awt.color;
import java.awt.font;
import java.awt.graphics;
import java.awt.image.bufferedimage;
import java.util.random;
import javax.imageio.imageio;
import javax.servlet.http.httpservletrequest;
import javax.servlet.http.httpservletresponse;
import javax.servlet.http.httpsession;
public class randomvalidatecode {
 public static final string randomcodekey = "randomcode_key";//放到session中的key
 private random random = new random();
 private string randstring = "0123456789abcdefghijklmnopqrstuvwxyz";//随机产生的字符串
 private int width = 80;//图片宽
 private int height = 26;//图片高
 private int linesize = 40;//干扰线数量
 private int stringnum = 4;//随机产生字符数量
 /**
  * 生成随机图片
  */
 public void getrandcode(httpservletrequest request,
   httpservletresponse response) {
  httpsession session = request.getsession();
  //bufferedimage类是具有缓冲区的image类,image类是用于描述图像信息的类
  bufferedimage image = new bufferedimage(width,height,bufferedimage.type_int_bgr);
  //产生image对象的graphics对象,改对象可以在图像上进行各种绘制操作
  graphics g = image.getgraphics();
  g.fillrect(0, 0, width, height);
  g.setfont(new font("times new roman",font.roman_baseline,18));
  g.setcolor(getrandcolor(160, 200));
  //绘制干扰线
  for(int i=0;i<=linesize;i++){
   drowline(g);
  }
  //绘制随机字符
  string randomstring = "";
  for(int i=1;i<=stringnum;i++){
   randomstring=drowstring(g,randomstring,i);
  }
  session.removeattribute(randomcodekey);
  session.setattribute(randomcodekey, randomstring);
  g.dispose();
  try {
   //将内存中的图片通过流动形式输出到客户端
   imageio.write(image, "jpeg", response.getoutputstream());
  } catch (exception e) {
   e.printstacktrace();
  }
 }
 /*
  * 获得字体
  */
 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);
 }
 /*
  * 绘制字符串
  */
 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 类写前端 ui 的接口
/**
* 获取生成验证码显示到 ui 界面
* @param request
* @param response
* @throws servletexception
* @throws ioexception
*/
@requestmapping(value="/checkcode")
public void checkcode(httpservletrequest request, httpservletresponse response)
  throws servletexception, ioexception {
//设置相应类型,告诉浏览器输出的内容为图片
 response.setcontenttype("image/jpeg");
 //设置响应头信息,告诉浏览器不要缓存此内容
 response.setheader("pragma", "no-cache");
 response.setheader("cache-control", "no-cache");
 response.setdateheader("expire", 0);
 randomvalidatecode randomvalidatecode = new randomvalidatecode();
 try {
  randomvalidatecode.getrandcode(request, response);//输出图片方法
 } catch (exception e) {
  e.printstacktrace();
 }
}
第三步:jsp 页面获取验证码
<img src="checkCode" alt="" width="100" height="32" class="passcode" style="height:43px;cursor:pointer;" onclick="this.src=this.src+'?'">
第四步:我的是在 ssm 环境下实现的,如果不是的话可以自己改写下。
总结
以上所述是小编给大家介绍的ssm 实现登录验证码功能,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对CodeAE代码之家网站的支持!
原文链接:https://blog.csdn.net/weidong_y/article/details/80630383


关注下面的标签,发现更多相似文章