很多新手对图片验证码不是很了解,今天我们就来看看一个实例吧!
首先,先写一个动态图片生成的Servlet类。
如下:
package com.validationCode;
import java.awt.Color;
import java.awt.Font;
import java.awt.Graphics;
import java.awt.image.BufferedImage;
import java.io.ByteArrayOutputStream;
import java.io.IOException;
import java.util.Random;
import javax.imageio.ImageIO;
import javax.servlet.ServletException;
import javax.servlet.ServletOutputStream;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession;
public class RandomCode extends HttpServlet {
private static final long serialVersionUID = 1L;
private static int WIDTH = 65;//设置图片的宽度
private static int HEIGHT = 22;//设置图片的高度
public void doGet(HttpServletRequest request,HttpServletResponse response) throws ServletException, IOException {
HttpSession session = request.getSession();
response.setContentType("image/jpeg");
ServletOutputStream sos = response.getOutputStream();
response.setHeader("Pragma", "No-cache");
response.setHeader("Cache-Control", "no-cache");
response.setDateHeader("Expires", 0);
BufferedImage image = new BufferedImage(WIDTH, HEIGHT,
BufferedImage.TYPE_INT_RGB);
Graphics g = image.getGraphics();
char[] rands = generateCheckCode();
drawBackground(g);
drawRands(g, rands);
g.dispose();
ByteArrayOutputStream bos = new ByteArrayOutputStream();
ImageIO.write(image, "JPEG", bos);
byte[] buf = bos.toByteArray();
response.setContentLength(buf.length);
sos.write(buf);
bos.close();
sos.close();
session.setAttribute("randomCode", new String(rands));
}
private void drawBackground(Graphics g) {
g.setColor(new Color(0xDCDCDC));
g.fillRect(0, 0, WIDTH, HEIGHT);
for (int i = 0; i < 120; i++) {
int x = (int) (Math.random() * WIDTH);
int y = (int) (Math.random() * HEIGHT);
int red = (int) (Math.random() * 255);
int green = (int) (Math.random() * 255);
int blue = (int) (Math.random() * 255);
g.setColor(new Color(red, green, blue));
g.drawOval(x, y, 1, 0);
}
}
private void drawRands(Graphics g, char[] rands) {
// g.setColor(Color.BLUE);
Random random = new Random();
int red = random.nextInt(110);
int green = random.nextInt(50);
int blue = random.nextInt(50);
g.setColor(new Color(red, green, blue));
g.setFont(new Font(null, Font.ITALIC | Font.BOLD, 18));
g.drawString("" + rands[0], 1, 17);
g.drawString("" + rands[1], 16, 15);
g.drawString("" + rands[2], 31, 18);
g.drawString("" + rands[3], 46, 16);
}
private char[] generateCheckCode() {
String chars = "0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ";
char[] rands = new char[4];
for (int i = 0; i < 4; i++) {
int rand = (int) (Math.random() * 36);
rands[i] = chars.charAt(rand);
}
return rands;
}
public void doPost(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
this.doGet(request, response);
}
}
然后保存为RandomCode.java。
然后进行编译,生成RandomCode.class文件,放到WEB-INF/classes/com/validationCode目录下;
然后修改WEB-INF目录中的web.xml,添加Servlet配置:
<servlet>
<servlet-name>RandomCodeServlet</servlet-name>
<servlet-class>org.yuanliang.RandomCode</servlet-class>
</servlet>
<servlet-mapping>
<servlet-name>RandomCodeServlet</servlet-name>
<url-pattern>/imgcode</url-pattern>
</servlet-mapping>
最后,在JSP页面中加入动态生成的图片验证码.
如: <img src="imgcode"/>
这时新的问题来了,如果用户看不清楚这个图片怎么为呢?
对了,就是加入刷新功能.
说两种简单的方法吧:
1.直接点击图片更换验证码:
可用JS脚本,添加如下代码到JSP页面中:
<script type="text/javascript">
function changeCode()
{
document.getElementById("rc").src="imgcode";
}
</script>
更改验证图片导入的代码:
<img src="imgcode" id="rc" onclick="changeCode()" title="看不清?单击换一张图片" />
2.添加文字链接,使其更换:
<a href="javascript:changeCode();">看不清?单击换一张图片</a>
OK!!!运行JSP页面,效果出来了。
分享到:
相关推荐
JSP 生成随机验证码图片(经典老代码)
在本主题“利用jsp生成图片验证码”中,我们将探讨如何在JavaServer Pages (JSP)上下文中创建一个简单的图片验证码,而无需使用Servlet。首先,我们要明白JSP是Java Web开发中的视图层技术,它允许我们在HTML页面中...
【标题】"jsp图片验证码源代码 自由模块"涉及的知识点主要集中在Java服务器页面(JSP)技术、图片验证码的实现以及模块化的编程思想。验证码通常用于防止自动化程序(如机器人)对网站进行恶意操作,例如批量注册、...
Description: 该文章讲述了如何使用 JSP 实现注册页面验证码验证代码,代码使用请有基础 JSP 基础,知道将代码添加到哪里,文章中已做详细阐述。 Tag: JSP、验证码、代码、表单验证 Knowledge Points: 1. JSP ...
1. 图片验证码: 这是最常见的验证码类型,通过生成随机字符串并将其绘制到图片上,再将图片发送给客户端。JSP可以通过Java的Graphics2D类来绘制文字和背景噪声,增加破解难度。同时,服务器会保存这个字符串,以便...
在Web开发中,使用JSP(JavaServer Pages)来生成验证码图片是一种常见的方法。下面我们将详细讨论如何在JSP中实现验证码的生成。 首先,我们需要理解验证码的基本原理。验证码通常包含一串随机的字母和数字,有时...
这段代码首先生成了一个4位随机数字的验证码,然后创建了一个图片并绘制了验证码以及干扰线,最后将验证码保存到session,并将生成的图像以JPEG格式输出到浏览器。 `Random.txt`可能是一个简单的文本文件,用于记录...
### JSP代码实现验证码功能详解 #### 一、概述 本文档详细介绍了如何使用Java Server Pages (JSP)技术来实现一个简单的验证码功能。验证码在Web应用中是一种常见的安全措施,用于防止自动化软件进行恶意操作,如...
在IT行业中,数字验证码是一种广泛应用于网站安全验证的技术,它主要用于...以上就是关于“一个jsp数字验证码的代码”的主要知识点。理解并掌握这些内容,开发者就能创建自己的JSP数字验证码系统,提升网站的安全性。
首先,JSP是Java平台上的动态网页技术,它允许开发人员在HTML或者XML文档中嵌入Java代码,使得服务器端能够处理业务逻辑并生成动态内容。在本项目中,JSP将用于构建登录页面的前端展示以及处理用户提交的登录请求。 ...
本文介绍了如何使用JSP技术动态生成验证码图片。这种方法不仅能够有效提升网站的安全性,还能根据实际需求灵活配置。开发者可以根据具体的应用场景对代码进行适当的调整,以满足不同的安全等级需求。
本文将深入解析JSP中实现图片验证码的主要技术和步骤。 首先,我们需要理解如何生成一张图片。在Java中,我们可以利用`java.awt`包下的类来实现这一目标。`HelloImage.java`示例代码展示了生成图片的基本流程: 1....
生成JSP图片验证码的过程包括以下几个关键步骤: 1. **生成随机字符串**:首先,我们需要创建一个包含字母和数字的随机字符串。这可以通过Java的`Random`类和`StringBuilder`类来实现,或者使用更安全的`...
本案例通过JSP技术实现了一个动态生成包含四个随机数字的图片验证码的功能,并且每次刷新时都会产生新的验证码及不同的背景颜色。 #### 二、关键技术点解析 ##### 1. 验证码生成原理 验证码通常由随机数字或字母...
在IT领域,JSP(JavaServer Pages)是一种用于创建动态网页的技术,它允许开发者将Java代码嵌入到HTML页面中,以实现服务器端的逻辑处理。在这个特定的案例中,我们关注的是一个JSP验证码的实现,其核心功能是生成4...
- **JSP (JavaServer Pages)**: Java平台上的动态网页技术。 - **Struts**: 一个基于MVC模式的Java Web框架。 - **HTML**: 前端标记语言。 - **Apache Commons Lang**: 提供了一系列辅助类和工具方法的库。 #### 三...
总的来说,生成JSP图片验证码涉及了Java图像处理、随机数生成、Session管理等多个知识点。通过合理的实现,可以有效地防止自动化攻击,保护网站的安全。在实践中,我们需要不断优化验证码的设计,以平衡用户体验和...
总结,这个"验证码jsp源代码"实例展示了如何利用JSP和Servlet创建一个简单的验证码登录系统,涵盖了服务器端动态页面生成、会话管理、表单提交验证等多个核心知识点。通过深入理解这些概念,开发者可以构建更复杂、...
### JSP登录验证码的源代码解析 #### 一、引言 在Web应用程序的安全性设计中,验证码(CAPTCHA)是一种常见的技术手段,用于区分用户是人类还是自动化软件。本篇文章将详细介绍一个基于JSP实现的登录验证码源代码,...