JSP 制作验证码的实例详解

发布时间 - 2026-01-11 02:52:26    点击率:

JSP 制作验证码的实例详解

 验证码

  验证码(CAPTCHA)是“Completely Automated Public Turing test to tell Computers and Humans Apart”(全自动区分计算机和人类的图灵测试)的缩写,是一种区分用户是计算机还是人的公共全自动程序。可以防止:恶意破解密码、刷票、论坛灌水,有效防止某个黑客对某一个特定注册用户用特定程序暴力破解方式进行不断的登陆尝试,实际上用验证码是现在很多网站通行的方式,我们利用比较简易的方式实现了这个功能。这个问题可以由计算机生成并评判,但是必须只有人类才能解答。由于计算机无法解答CAPTCHA的问题,所以回答出问题的用户就可以被认为是人类。

   Jsp制作验证码

  运行环境:tomcat+eclipse+jdk

  基本思想:现在Servlet上画出验证码的图片,让其显示到页面上,再用js方法能刷新验证码,可以用ajax得到用户输入的值经过servlet跟验证码比对判断是否,并符合提示用户

  基本方法:  

BufferedImage: 

Image是一个抽象列,BufferedImage是Image的实现。


Image和BufferedImage的主要作用就是将一副图片加载到内存中。
Java将一副图片加载到内存中的方法是:
Java代码 
String imgPath = "d:/demo.jpg"; 
BufferedImage image = ImageIO.read(new FileInputStream(imgPath)); 
该方法可以获得图片的详细信息,例如:获得图片的宽度:image.getWidth(null);图片只有加载内存中才能对图片进行进一步的处理。


Graphics: 

Graphics类提供基本的几何图形绘制方法,主要有:画线段、画矩形、画圆、画带颜色的图形、画椭圆、画圆弧、画多边形等,具体操作其内容我推荐可以看看使用Java的Graphics类进行绘图的方法详解

  验证码的代码实现

  我这里做的验证码是显示中文的,可以在servlet中修改想要显示的是数字还是字母还是结合的,可以用数组存放这些,也可以转换ASCII码经行随机数字,看个人喜好

  先是做一个jsp中的验证码的地方

<div class="row cl">
    <div>
     <input type="text" placeholder="验证码" value="验证码:" onblur="testCheck(this.value);">
     <img id="pic" src="CheckTestServlet"> <a id="kanbuq" onClick="Checktest();">看不清,换一张</a> </div>
 </div>

  在做一个Servlet叫做CheckTestServlet.java

@WebServlet("/CheckTestServlet")
public class CheckTestServlet extends HttpServlet {
  private static final long serialVersionUID = 1L;
    
  
  protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
          //这个方法实现验证码的生成
          response.setCharacterEncoding("utf-8");
          //创建图片缓冲区设置其大小  BufferedImage(int width, int height, int imageType) 
         BufferedImage bImage=new BufferedImage(100, 30, BufferedImage.TYPE_3BYTE_BGR);
         //在缓冲区上创建画布
         Graphics g=bImage.getGraphics();
         //设置背景颜色
         g.setColor(Color.orange);
         //创建画布矩形,位置(0,0)点,大小100,30
         g.fillRect(0, 0, 100, 30);
         //创建随机对象
         Random r=new Random();
         int index;//存放随机数
         //得到的文字东西存放处
         StringBuffer sBuffer=new StringBuffer();
         //循环产生四个字
         for (int i = 0; i < 4; i++) {
           //中文字的第一个十六进制码为4e00转十进制是19968,最后一个是9fa0十进制为40869,所以可以产生在此之间的随机数
           index=r.nextInt(40869-19968+1)+19968;//产生随机数字
           //设置随机颜色,
           g.setColor(new Color(r.nextInt(255), r.nextInt(255), r.nextInt(255)));
           //设置文字的类型,大小
           g.setFont(new Font("", Font.BOLD, 20));
           /*画字,将随机数字转换成十六进制Integer.toHexString(index),16)再转换字符(char)(Integer.parseInt,
           在设置每个文字的位置
           */
           g.drawString((char)(Integer.parseInt(Integer.toHexString(index),16))+"", i*22+4, 18);
           //将其存放在StringBuffer中,以便后面读取作比较
           sBuffer.append((char)(Integer.parseInt(Integer.toHexString(index),16)));
        }
         //将得到的文字设置到session中
         request.getSession().setAttribute("piccode", sBuffer.toString());
         /*将这个验证码图片读写到页面中
          * write(RenderedImage im, String formatName, OutputStream output)
        */         
         ImageIO.write(bImage, "jpg", response.getOutputStream());
  }

  protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
    // TODO Auto-generated method stub
    doGet(request, response);
  }

  在做一个js刷新验证码的,用于看不清,或者别的刷新用处

 function Checktest(){
     var time=new Date().getTime();
    $("#pic").attr('src',"CheckTestServlet?d="+time)
  }

  再写一个Ajax去验证用户输入的是否正确返回提示,这是用jQuery做的,需要引js

function testCheck(num){
    $.ajax({
      type:"post",//提交方式
      url:"TestCheckServlet",//提交地址
      async:true,//是否异步请求
      dataType:"html",//返回类型
      data:{"num":num},//传过去的值
      success:function(data,textStatus){//成功执行的方法
        $("#checks").html(data)
      },
      error:function(){//失败执行的方法
        alert("error");
      }
    })
  } 

  有点麻烦的再去做一个Servlet去验证Ajax传过来的值是否匹配验证码

@WebServlet("/TestCheckServlet")
public class TestCheckServlet extends HttpServlet {
  private static final long serialVersionUID = 1L;
  
  protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
    response.setCharacterEncoding("utf-8");
    PrintWriter out=response.getWriter();
    //得到输入的验证码与随机的图片验证码作比较,判断是否相等,返回提示用户,
    if (request.getSession().getAttribute("piccode").toString().equals(request.getParameter("num"))) {
      out.println("验证码正确");
    }else {
      out.println("验证码错误");
    }
  }


  protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
    // TODO Auto-generated method stub
    doGet(request, response);
  }

}

就这样验证码已经基本搞定,其中还有许多需要修改的内容,花样,根据需求而来

 以上就是二维码的制作,如有疑问请留言或者到本站社区交流讨论,感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!


# JSP  # 验证码  # 验证码的制作步骤  # 验证码的实例  # jsp页面验证码完整实例  # JSP实用教程之简易图片验证码的实现方法(附源码)  # JSP实现登录功能之添加验证码  # jsp页面验证码demo  # JSP验证码动态生成方法  # jsp+Servlet编程实现验证码的方法  # jsp+ajax实现的局部刷新较验验证码(onblur事件触发较验)  # jsp实现简单验证码的方法  # 做一个  # 随机数  # 可以用  # 加载  # 的是  # 判断是否  # 是一个  # 这是  # 运行环境  # 是一种  # 放在  # 第一个  # 在此  # 如有  # 而来  # 这个问题  # 将其  # 希望能  # 注册用户 


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


相关推荐: EditPlus中的正则表达式 实战(4)  详解Nginx + Tomcat 反向代理 负载均衡 集群 部署指南  Win11应用商店下载慢怎么办 Win11更改DNS提速下载【修复】  Python并发异常传播_错误处理解析【教程】  猎豹浏览器开发者工具怎么打开 猎豹浏览器F12调试工具使用【前端必备】  javascript如何操作浏览器历史记录_怎样实现无刷新导航  制作旅游网站html,怎样注册旅游网站?  Laravel如何使用Facades(门面)及其工作原理_Laravel门面模式与底层机制  HTML 中如何正确使用模板变量为元素的 name 属性赋值  rsync同步时出现rsync: failed to set times on “xxxx”: Operation not permitted  重庆市网站制作公司,重庆招聘网站哪个好?  5种Android数据存储方式汇总  三星网站视频制作教程下载,三星w23网页如何全屏?  手机网站制作平台,手机靓号代理商怎么制作属于自己的手机靓号网站?  焦点电影公司作品,电影焦点结局是什么?  JavaScript如何实现路由_前端路由原理是什么  如何在Windows虚拟主机上快速搭建网站?  魔方云NAT建站如何实现端口转发?  胶州企业网站制作公司,青岛石头网络科技有限公司怎么样?  公司网站制作需要多少钱,找人做公司网站需要多少钱?  Midjourney怎样加参数调细节_Midjourney参数调整技巧【指南】  长沙企业网站制作哪家好,长沙水业集团官方网站?  iOS正则表达式验证手机号、邮箱、身份证号等  Android利用动画实现背景逐渐变暗  Laravel如何处理JSON字段_Eloquent原生JSON字段类型操作教程  微信小程序 五星评分(包括半颗星评分)实例代码  百度浏览器如何管理插件 百度浏览器插件管理方法  大连网站制作公司哪家好一点,大连买房网站哪个好?  网站制作大概多少钱一个,做一个平台网站大概多少钱?  大连企业网站制作公司,大连2025企业社保缴费网上缴费流程?  进行网站优化必须要坚持的四大原则  Linux系统命令中tree命令详解  HTML5建模怎么导出为FBX格式_FBX格式兼容性及导出步骤【指南】  如何快速上传自定义模板至建站之星?  php后缀怎么变mp4格式错误_修改扩展名提示格式不对怎么办【技巧】  Laravel如何实现文件上传和存储?(本地与S3配置)  Laravel如何使用Sanctum进行API认证?(SPA实战)  香港服务器租用费用高吗?如何避免常见误区?  什么是JavaScript解构赋值_解构赋值有哪些实用技巧  Laravel如何实现多级无限分类_Laravel递归模型关联与树状数据输出【方法】  如何在阿里云高效完成企业建站全流程?  Java解压缩zip - 解压缩多个文件或文件夹实例  如何在局域网内绑定自建网站域名?  Swift中swift中的switch 语句  php8.4header发送头信息失败怎么办_php8.4header函数问题解决【解答】  Laravel怎么实现验证码(Captcha)功能  黑客入侵网站服务器的常见手法有哪些?  Zeus浏览器网页版官网入口 宙斯浏览器官网在线通道  湖南网站制作公司,湖南上善若水科技有限公司做什么的?  如何在服务器上三步完成建站并提升流量?