java 制作验证码并进行验证实例详解

发布时间 - 2026-01-11 00:48:20    点击率:

java 制作验证码并进行验证实例详解

在注册、登录的页面上经常会出现验证码,为了防止频繁的注册或登录行为。下面是我用java制作的一个验证码,供初学者参考,做完验证码之后,我们可以用ajax进行验证码验证。

功能一:验证码制作的代码,点击图片,验证码进行更换

/**
 * 显示验证码图片
 */
public void showCheckCode(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
  // 调用业务逻辑
  String checkCode = getCheckCode();
  //将验证码字符放入session域对象中
  req.getSession().setAttribute("checkCode", checkCode);

  //图片宽
  int width = 80;
  //图片高
  int height = 30;
  //在内存中创建一个图片
  BufferedImage image = new BufferedImage(width,height,BufferedImage.TYPE_INT_RGB);
  //获取一个画笔
  Graphics g = image.getGraphics();
  //设置画笔颜色,用灰色做背景
  g.setColor(Color.GRAY);
  //向Image中填充灰色
  g.fillRect(0,0,width,height);

  Random r = new Random();

  //设置3条干扰线
  for (int i = 0; i < 3; i++) {
    g.setColor(new Color(r.nextInt(255),r.nextInt(255),r.nextInt(255)));
    g.drawLine(r.nextInt(80), r.nextInt(30), r.nextInt(80), r.nextInt(80));
  }

  //设置验证码字符串的颜色
  g.setColor(new Color(r.nextInt(255),r.nextInt(255),r.nextInt(255)));
  //设置字符的大小
  g.setFont(new Font("黑体",Font.BOLD,24));
  //在图片中写入验证码字符串
  g.drawString(checkCode,15,20);
  //将Image对象以PNG格式输出给所有的客户端
  ImageIO.write(image,"PNG",resp.getOutputStream());
}

/**
 * 获取4位验证码中的4位随机字符串
 */
public static String getCheckCode(){
  //验证码中的字符由数字和大小写字母组成
  String code = "0123456789qwertyuiopasdfghjklzxcvbnmQWERTYUIOPASDFGHJKLZXCVBNM";
  Random r = new Random();
  StringBuffer sb = new StringBuffer();
  for (int i = 0; i < 4; i++) {
    sb.append(code.charAt(r.nextInt(code.length())));
  }

  return sb.toString();
}

jsp页面

<script type="text/javascript">
  function changeCodeImage(img){
    img.src = "${pageContext.request.contextPath}/UserServlet?method=showCheckCode&time="+new Date().getTime();
  }

</script>

 <div class="form-group">
  <label for="date" class="col-sm-2 control-label">验证码</label>
  <div class="col-sm-3">
   <input type="text" class="form-control" id="writeCode" onkeyup="checkCodeMethod(this.value)" >

  </div>
  <div class="col-sm-2">
  <img src="${pageContext.request.contextPath}/UserServlet?method=showCheckCode" id="checkCodeImage" title="点击换一张" onclick="changeCodeImage(this)" />
  </div>
  <span id="checkCodeSpan"></span>
 </div>

功能二:ajax动态验证验证码

/**
 * 验证验证码
 */
public void checkCode(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {

  //获取从页面中接收到的验证码参数
  String checkCode = req.getParameter("checkCode");
  //从session域对象中获取验证码
  String sessionCode = (String) req.getSession().getAttribute("checkCode");
  //判断验证码是否相同
  if (checkCode.equalsIgnoreCase(sessionCode)) {
    resp.getWriter().print(true);
  }else {
    resp.getWriter().print(false);
  }

jsp页面

<script type="text/javascript">
  function changeCodeImage(img){
    img.src = "${pageContext.request.contextPath}/UserServlet?method=showCheckCode&time="+new Date().getTime();
  }

  function checkCodeMethod(code){
    $.get("${pageContext.request.contextPath}/UserServlet?method=checkCode", 
        { checkCode: code}, 
        function(data){
          if (data == 'true') {
            document.getElementById("checkCodeSpan").innerHTML = "<font>验证码正确!</font>";
          }else {
            document.getElementById("checkCodeSpan").innerHTML = "<font>验证码错误!</font>";
          }
        }
      );
  }

</script>

 <div class="form-group">
  <label for="date" class="col-sm-2 control-label">验证码</label>
  <div class="col-sm-3">
   <input type="text" class="form-control" id="writeCode" onkeyup="checkCodeMethod(this.value)" >

  </div>
  <div class="col-sm-2">
  <img src="${pageContext.request.contextPath}/UserServlet?method=showCheckCode" id="checkCodeImage" title="点击换一张" onclick="changeCodeImage(this)" />
  </div>
  <span id="checkCodeSpan"></span>
 </div>

感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!


# java  # 制作验证码并进行验证  # 制作验证码  # java 图片验证码的实现代码  # Java实现验证码具体代码  # Java 随机生成验证码(支持大小写字母、数字、随机字体)的实例  # java实现验证码类生成中文验证码  # java生成图片验证码示例程序  # 解析Java实现随机验证码功能的方法详解  # java图片验证码实现示例分享  # 验证码  # 象中  # 可以用  # 我用  # 希望能  # 谢谢大家  # 做完  # 经常会  # 创建一个  # 为了防止  # 客户端  # 写字母  # 验证码错误  # Graphics  # image  # TYPE_INT_RGB  # getGraphics  # GRAY  # Color  # setColor 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: PHP 实现电台节目表的智能时间匹配与今日/明日轮播逻辑  如何在阿里云虚拟机上搭建网站?步骤解析与避坑指南  HTML5打空格有哪些误区_新手常犯的空格使用错误【技巧】  如何快速查询域名建站关键信息?  Laravel如何实现图片防盗链功能_Laravel中间件验证Referer来源请求【方案】  jQuery validate插件功能与用法详解  如何在自有机房高效搭建专业网站?  JavaScript中如何操作剪贴板_ClipboardAPI怎么用  JS弹性运动实现方法分析  谷歌浏览器下载文件时中断怎么办 Google Chrome下载管理修复  Laravel DB事务怎么使用_Laravel数据库事务回滚操作  如何在香港服务器上快速搭建免备案网站?  Laravel如何为API生成Swagger或OpenAPI文档  Win11怎么关闭资讯和兴趣_Windows11任务栏设置隐藏小组件  JavaScript如何实现错误处理_try...catch如何捕获异常?  Laravel如何自定义错误页面(404, 500)?(代码示例)  什么是javascript作用域_全局和局部作用域有什么区别?  惠州网站建设制作推广,惠州市华视达文化传媒有限公司怎么样?  Laravel集合Collection怎么用_Laravel集合常用函数详解  Laravel如何实现API资源集合?(Resource Collection教程)  如何在阿里云虚拟主机上快速搭建个人网站?  Laravel如何使用集合(Collections)进行数据处理_Laravel Collection常用方法与技巧  电商网站制作多少钱一个,电子商务公司的网站制作费用计入什么科目?  在线制作视频的网站有哪些,电脑如何制作视频短片?  深圳网站制作的公司有哪些,dido官方网站?  教你用AI润色文章,让你的文字表达更专业  Laravel Admin后台管理框架推荐_Laravel快速开发后台工具  成都品牌网站制作公司,成都营业执照年报网上怎么办理?  网站建设保证美观性,需要考虑的几点问题!  Laravel辅助函数有哪些_Laravel Helpers常用助手函数大全  胶州企业网站制作公司,青岛石头网络科技有限公司怎么样?  Laravel如何优雅地处理服务层_在Laravel中使用Service层和Repository层  如何在云虚拟主机上快速搭建个人网站?  Laravel观察者模式如何使用_Laravel Model Observer配置  如何在VPS电脑上快速搭建网站?  详解阿里云nginx服务器多站点的配置  如何用VPS主机快速搭建个人网站?  Bootstrap整体框架之JavaScript插件架构  如何在IIS中新建站点并配置端口与IP地址?  android nfc常用标签读取总结  七夕网站制作视频,七夕大促活动怎么报名?  Laravel怎么实现微信登录_Laravel Socialite第三方登录集成  JavaScript如何实现音频处理_Web Audio API如何工作?  谷歌Google入口永久地址_Google搜索引擎官网首页永久入口  Laravel如何使用Gate和Policy进行权限控制_Laravel权限判定与策略规则配置  悟空浏览器如何设置小说背景色_悟空浏览器背景色设置【方法】  进行网站优化必须要坚持的四大原则  如何获取免费开源的自助建站系统源码?  canvas 画布在主流浏览器中的尺寸限制详细介绍  Laravel如何安装使用Debugbar工具栏_Laravel性能调试与SQL监控插件【步骤】