Java Web开发中验证码的实现(JSP验证码)

本文涉及的产品
函数计算FC,每月15万CU 3个月
简介:

通常的登录注册系统都会要求输入验证码以区别用户行为和计算机程序行为来防止恶意注册、暴力破解密码等。

Jsp或者Java Web开发中通常用 Java 的 Graphics 绘制验证码图片然后用ImageIO输出为Jpg等格式的图片再通过Session来验证输入内容与验证码内容的一致性。

具体代码和步骤如下:

1.生成验证码的Servlet

 

 
  1. Java 代码复制内容到剪贴板  
  2.       
  3. import java.io.IOException;            
  4. import javax.servlet.ServletException;            
  5. import javax.servlet.http.HttpServlet;            
  6. import javax.servlet.http.HttpServletRequest;            
  7. import javax.servlet.http.HttpServletResponse;            
  8. import javax.servlet.http.HttpSession;            
  9. import java.util.*;            
  10. import java.awt.*;            
  11. import java.awt.image.*;            
  12.             
  13. import javax.imageio.*;            
  14. /**       
  15. *         
  16. * @author mzba       
  17. *       
  18. */          
  19. public class GetCaptcha extends HttpServlet {            
  20.     private static final long serialVersionUID = 1L;            
  21.             
  22.     /**         
  23.      * @see HttpServlet#HttpServlet()         
  24.      */            
  25.     public GetCaptcha() {            
  26.         super();            
  27.         // TODO Auto-generated constructor stub            
  28.     }            
  29.             
  30.     /**         
  31.      * @see HttpServlet#doGet(HttpServletRequest request, HttpServletResponse         
  32.      *      response)         
  33.      */            
  34.     protected void doGet(HttpServletRequest request,            
  35.             HttpServletResponse response) throws ServletException, IOException {            
  36.         response.setContentType("image/jpeg");            
  37.         response.setHeader("Pragma", "No-cache");            
  38.         response.setHeader("Cache-Control", "no-cache");            
  39.         response.setDateHeader("Expires", 0);            
  40.         HttpSession session = request.getSession();            
  41.         // 在内存中创建图象            
  42.         int width = 75height = 25;            
  43.         BufferedImage image = new BufferedImage(width, height,            
  44.                 BufferedImage.TYPE_INT_RGB);            
  45.         // 获取图形上下文            
  46.         Graphics g = image.getGraphics();            
  47.         // 生成随机类            
  48.         Random random = new Random();            
  49.         // 设定背景色            
  50.         g.setColor(getRandColor(200, 250));            
  51.         g.fillRect(0, 0, width, height);            
  52.         // 设定字体            
  53.         g.setFont(new Font("Times New Roman", Font.PLAIN, 24));            
  54.         // 画边框            
  55.         g.setColor(getRandColor(160, 200));            
  56.         g.drawRect(0, 0, width - 1, height - 1);            
  57.         // 随机产生155条干扰线,使图象中的认证码不易被其它程序探测到            
  58.         g.setColor(getRandColor(160, 200));            
  59.         for (int i = 0; i < 155; i++) {            
  60.             int x = random.nextInt(width);            
  61.             int y = random.nextInt(height);            
  62.             int xl = random.nextInt(12);            
  63.             int yl = random.nextInt(12);            
  64.             g.drawLine(x, y, x + xl, y + yl);            
  65.         }            
  66.         // 取随机产生的认证码(4位数字)            
  67.         String sRand = "";            
  68.         for (int i = 0; i < 4; i++) {            
  69.             String rand = String.valueOf(random.nextInt(10));            
  70.             sRand += rand;            
  71.             // 将认证码显示到图象中            
  72.             g.setColor(new Color(20 + random.nextInt(110), 20 + random            
  73.                     .nextInt(110), 20 + random.nextInt(110)));            
  74.             // 调用函数出来的颜色相同,可能是因为种子太接近,所以只能直接生成            
  75.             g.drawString(rand, 13 * i + 14, 20);            
  76.         }            
  77.             
  78.         // 将认证码存入SESSION            
  79.         session.setAttribute("vcode", sRand);            
  80.             
  81.         // 图象生效            
  82.         g.dispose();            
  83.         // 输出图象到页面            
  84.         ImageIO.write(image, "JPEG", response.getOutputStream());            
  85.     }            
  86.             
  87.     /**         
  88.      * @see HttpServlet#doPost(HttpServletRequest request, HttpServletResponse         
  89.      *      response)         
  90.      */            
  91.     protected void doPost(HttpServletRequest request,            
  92.             HttpServletResponse response) throws ServletException, IOException {            
  93.         // TODO Auto-generated method stub            
  94.     }            
  95.             
  96.     Color getRandColor(int fc, int bc) {// 给定范围获得随机颜色            
  97.         Random random = new Random();            
  98.         if (fc > 255)            
  99.             fc = 255;            
  100.         if (bc > 255)            
  101.             bc = 255;            
  102.         int r = fc + random.nextInt(bc - fc);            
  103.         int g = fc + random.nextInt(bc - fc);            
  104.         int b = fc + random.nextInt(bc - fc);            
  105.         return new Color(r, g, b);            
  106.     }            
  107.             
  108. }        

2.web.xml中添加上面Servlet的映射信息


 

 
  1. XML/HTML 代码复制内容到剪贴板  
  2.       
  3. <servlet>            
  4.    <description>用于生成验证码</description>            
  5.    <display-name>生成验证码</display-name>            
  6.    <servlet-name>GetCaptcha</servlet-name>            
  7.    <servlet-class>servlets.GetCaptcha</servlet-class>            
  8. </servlet>            
  9.           
  10. <servlet-mapping>            
  11.   <servlet-name>GetCaptcha</servlet-name>            
  12.   <url-pattern>/getcaptcha.sl</url-pattern>            
  13. </servlet-mapping>    

3.在前台界面中调用此Servlet

 

 
  1. XML/HTML 代码复制内容到剪贴板  
  2.       
  3. <img src="getcaptcha.sl" alt="验证码" name="checkImg" id="checkImg" style="position:relative; top:5px; left:20px; " onClick="document.getElementById('checkImg').src='getcaptcha.sl?temp='+ (new Date().getTime().toString(36)); return false"/>        

 



     本文转自06peng 51CTO博客,原文链接:http://blog.51cto.com/06peng/962391,如需转载请自行联系原作者





相关实践学习
【文生图】一键部署Stable Diffusion基于函数计算
本实验教你如何在函数计算FC上从零开始部署Stable Diffusion来进行AI绘画创作,开启AIGC盲盒。函数计算提供一定的免费额度供用户使用。本实验答疑钉钉群:29290019867
建立 Serverless 思维
本课程包括: Serverless 应用引擎的概念, 为开发者带来的实际价值, 以及让您了解常见的 Serverless 架构模式
相关文章
|
22天前
|
前端开发 Oracle 关系型数据库
关于使用SSM+JSP开发时setter、getter隐式调用问题的小结
本文主要分享了在使用SSM+JSP进行网站开发时,因忽视setter、getter的隐式调用问题而导致的常见bug及其解决方法。详细介绍了setter和getter的隐式调用时机,并给出了具体示例,帮助开发者避免类似问题。
42 11
|
22天前
|
存储 安全 搜索推荐
理解Session和Cookie:Java Web开发中的用户状态管理
理解Session和Cookie:Java Web开发中的用户状态管理
47 4
|
22天前
|
Java 持续交付 项目管理
使用Maven进行项目管理:提高Java Web开发的效率
Maven 是一款强大的项目管理和构建自动化工具,广泛应用于Java社区。它通过依赖管理、构建生命周期管理、插件机制和多模块项目支持等功能,简化了项目的构建过程,提高了开发效率。本文将介绍Maven的核心功能及其在Java Web开发中的应用。
49 0
|
22天前
|
SQL XML 缓存
java中jsp详解!!!
JSP(Java Server Pages)是一种动态网页技术标准,允许在HTML页面中嵌入Java代码,实现网页逻辑与设计分离。JSP本质上是Servlet的简化,支持跨平台运行。JSP通过内置对象(如request、response、session等)和指令(如page、include、taglib)提供强大的功能,同时利用EL表达式和JSTL标签库简化页面开发。JSP的核心优势在于快速开发和维护Web应用。
36 0
|
4月前
|
缓存 安全 Java
Java服务器端技术:Servlet与JSP的集成与扩展
Java服务器端技术:Servlet与JSP的集成与扩展
38 3
|
4月前
|
存储 缓存 前端开发
Servlet与JSP在Java Web应用中的性能调优策略
Servlet与JSP在Java Web应用中的性能调优策略
35 1
|
4月前
|
Java Maven Android开发
解锁Web开发新技能:从零开始的Struts 2之旅——让你的Java编程之路更加宽广,首个应用实例带你飞!
【8月更文挑战第31天】对于初学者,掌握 Struts 2 框架不仅能提升 Web 开发能力,还能深入了解 MVC 架构。Struts 2 是一个基于 Servlet 的 Java 框架,提供表单验证、文件上传、国际化等功能,便于快速构建易维护的 Web 应用。本文通过示例演示如何从零开始搭建环境并创建一个简单的 Struts 2 项目,包括配置 `struts.xml`、编写 Action 类及视图文件,并配置 web.xml。通过这些步骤,你将学会基本的开发流程,为进一步学习高级功能打下基础。
50 0
|
4月前
|
Java Spring 开发者
Java Web开发新潮流:Vaadin与Spring Boot强强联手,打造高效便捷的应用体验!
【8月更文挑战第31天】《Vaadin与Spring Boot集成:最佳实践指南》介绍了如何结合Vaadin和Spring Boot的优势进行高效Java Web开发。文章首先概述了集成的基本步骤,包括引入依赖和配置自动功能,然后通过示例展示了如何创建和使用Vaadin组件。相较于传统框架,这种集成方式简化了配置、提升了开发效率并便于部署。尽管可能存在性能和学习曲线方面的挑战,但合理的框架组合能显著提升应用开发的质量和速度。
73 0
|
4月前
|
存储 Java 关系型数据库
基于Servlet和JSP的Java Web应用开发指南
基于Servlet和JSP的Java Web应用开发指南
61 0
|
2月前
|
XML JSON API
ServiceStack:不仅仅是一个高性能Web API和微服务框架,更是一站式解决方案——深入解析其多协议支持及简便开发流程,带您体验前所未有的.NET开发效率革命
【10月更文挑战第9天】ServiceStack 是一个高性能的 Web API 和微服务框架,支持 JSON、XML、CSV 等多种数据格式。它简化了 .NET 应用的开发流程,提供了直观的 RESTful 服务构建方式。ServiceStack 支持高并发请求和复杂业务逻辑,安装简单,通过 NuGet 包管理器即可快速集成。示例代码展示了如何创建一个返回当前日期的简单服务,包括定义请求和响应 DTO、实现服务逻辑、配置路由和宿主。ServiceStack 还支持 WebSocket、SignalR 等实时通信协议,具备自动验证、自动过滤器等丰富功能,适合快速搭建高性能、可扩展的服务端应用。
117 3