在网页页面的使用中为防止非人类的大量操作和防止一些的信息冗余,增加验证码校验是许多网站常用的方式。 而让用户输入字母和数字组合的验证码是最经典也是最常用的方式。 这
在网页页面的使用中为防止“非人类”的大量操作和防止一些的信息冗余,增加验证码校验是许多网站常用的方式。 而让用户输入字母和数字组合的验证码是最经典也是最常用的方式。 今天发布的第二篇文章是利用Hutool工具类来实现的,该工具类已经封装验证码所需的相关类等,使用起来较为简单和方便。 验证码的生成和校验过程均使用Servlet和JSP的结合来实现,Servlet的相关内容可以参阅Servlet技术 如何利用基础的JSP知识来实现网页的验证码校验呢? 验证码校验分析首先要验证码的校验的过程。 验证码校验分为三部分:
验证码的生成实际就是输出一个图像,所以在这里使用ImageIO来生成图片,然后结合使用随机数(Random)来实现随机生成验证上的内容,最后进而展示出来,然后利用Session对象存储验证码的内容。在用户输入验证码的时候可以用request来获取用户输入的内容,让其余Session对象中保存的验证码内容进行比较,若一致则验证成功,不一致就验证失败。 生成验证码先创建一个图片的缓冲区:
创建画布:
创建颜色:
创建背景颜色:
填充矩形:
将要显示的验证码内容组成元素存入字符串数组:
创建随机的验证码内容:
将验证码的内容存入Session及显示在页面上:
完整代码:
测试验证码在测试之前需要先在web.xml文件中配置一下:
启动服务器后在浏览器中输入http://localhost:8080/工程名/imageServlet 即可 验证码的生成已经实现成功,下面实现验证验证码的Servlet。 校验验证码先新建一个jsp用户界面:
校验验证码过程:
代码实现: 获取Session中的验证码内容:
获取用户输入的验证码内容:
验证码判断(使用了PrintWriter将相关内容输出)
完整代码:
测试验证码校验测试前先在web.xml文件中配置一下:
添加验证码刷新在验证码生成之后,用户在识别的时候可能不能正确识别,这时候就需要刷新一下重新生成。 添加超链接实现刷新: login.jsp:
js部分的Date相关是防止浏览器缓存后不能正常刷新,添加时间的唯一性来实现能够及时刷新和展示。 js 部分可以参阅:JavaScript 语言入门 也可以在ImageServlet中添加防止浏览器缓存的语句:
公众号本文地址:https://mp.weixin.qq.com/s/XHucabQ_WwUx2OMDGSTMkw |
2019-05-28
2022-01-29
2022-01-29
2022-01-29
2022-10-20