生成图片验证码的几个页面以及JAVA文件:
MakeCertPic.java
package cn.liuc.util;
import java.awt.Color;
import java.awt.Font;
import java.awt.Graphics;
import java.awt.image.BufferedImage;
import java.io.IOException;
import java.io.OutputStream;
import java.util.Random;
import javax.imageio.ImageIO;
/**
* @author dzy 生成验证码图片
*/
public class MakeCertPic {
// 验证码图片中可以出现的字符集,可根据需要修改
private char mapTable[] = { 'a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i',
'j', 'k', 'l', 'm', 'n', 'o', 'p', 'q', 'r', 's', 't', 'u', 'v',
'w', 'x', 'y', 'z', '0', '1', '2', '3', '4', '5', '6', '7', '8',
'9' };
/**
* 功能:生成彩色验证码图片 参数width为生成图片的宽度,参数height为生成图片的高度,参数os为页面的输出流
*/
public String getCertPic(int width, int height, OutputStream os) {
if (width <= 0)
width = 60;
if (height <= 0)
height = 20;
BufferedImage image = new BufferedImage(width, height,
BufferedImage.TYPE_INT_RGB);
// 获取图形上下文
Graphics g = image.getGraphics();
// 设定背景色
g.setColor(new Color(0xDCDCDC));
g.fillRect(0, 0, width, height);
// 画边框
g.setColor(Color.black);
g.drawRect(0, 0, width - 1, height - 1);
// 取随机产生的认证码
String strEnsure = "";
// 4代表4位验证码,如果要生成更多位的认证码,则加大数值
for (int i = 0; i < 4; ++i) {
strEnsure += mapTable[(int) (mapTable.length * Math.random())];
}
// 将认证码显示到图像中,如果要生成更多位的认证码,增加drawString语句
g.setColor(Color.black);
g.setFont(new Font("Atlantic Inline", Font.PLAIN, 18));
String str = strEnsure.substring(0, 1);
g.drawString(str, 8, 17);
str = strEnsure.substring(1, 2);
g.drawString(str, 20, 15);
str = strEnsure.substring(2, 3);
g.drawString(str, 35, 18);
str = strEnsure.substring(3, 4);
g.drawString(str, 45, 15);
// 随机产生10个干扰点
Random rand = new Random();
for (int i = 0; i < 10; i++) {
int x = rand.nextInt(width);
int y = rand.nextInt(height);
g.drawOval(x, y, 1, 1);
}
// 释放图形上下文
g.dispose();
try {
// 输出图像到页面
ImageIO.write(image, "JPEG", os);
} catch (IOException e) {
return "";
}
return strEnsure;
}
}
makeCertPic.jsp
<%@page import="java.io.OutputStream"%>
<%@ page language="java" pageEncoding="UTF-8"%>
<jsp:useBean id="image" scope="page" class="cn.liuc.util.MakeCertPic" />
<%
OutputStream os = response.getOutputStream();
String str = image.getCertPic(0, 0, os);
// 将认证码存入SESSION
session.setAttribute("certCode", str);
out.clear();
out=pageContext.pushBody();
%>
LoginPic.jsp
<%@ page contentType="text/html;charset=utf-8" %>
<html>
<head><title>登录页面</title></head>
<body>
<form action="loginCheck.jsp" method="post" >
验证码:<input type="text" name="certCode"/>
<img src="makeCertPic.jsp">
<input type="submit" value="确定"/>
</form>
</body>
</html>
loginCheck.jsp
<%@ page language="java" contentType="text/html; charset=UTF-8"
pageEncoding="UTF-8"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<%
String certCode=request.getParameter("certCode");
if(certCode.equals((String)session.getAttribute("certCode")))
out.print("验证码输入正确");
else
out.print("验证码输入错误");
%>
<html>
<head>
<title>Insert title here</title>
</head>
<body>
</body>
</html>
红色部分( makeCertPic.jsp的第十行)要格外注意,如果不加则会报java.lang.IllegalStateException: getOutputStream() has already been called for this response错误,
具体原因如下:
应用验证码时,都会用到字节流response.getOutputStream()来将验证码
输出,但是jsp页面自己最后会调用字符流JspWriter的out()方法将页面的内容输
出。通过查看servlet的API我们可以看到知道,在servlet中不能够同时利用这两
个流输出,解决办法将验证码写在servlet中或者在JSP的JAVA代码中加入
response.reset();
out.clear();
out=pageContext.pushBody();
分享到:
相关推荐
"SpringMVC生成的验证码图片不显示问题及解决方法" 知识点1: SpringMVC验证码图片生成 在SpringMVC中,生成验证码图片需要使用@Controller注解的Controller类,通过@RequestMapping注解的方法来处理验证码图片的...
总结一下,这个“vue插件——使用canvas生成图形验证码”结合了Vue.js的组件化和canvas的图形绘制能力,为Web应用提供了一种安全、可定制的图形验证码解决方案。它既保证了用户验证的安全性,又利用Vue.js的便利性...
总结来说,使用JSP生成图片验证码涉及到以下几个关键点:生成随机字符串、存储验证码、绘制并输出图片以及设置HTTP响应类型。这种方法简单易用,但要注意,对于高级的自动化攻击,可能需要更复杂的验证码解决方案,...
在本文中,我们将深入探讨验证码的工作原理,以及如何使用编程技术来实现一个图片验证码生成器。 验证码的主要目标是防止自动化程序(如机器人或爬虫)进行恶意操作,如批量注册、刷票或垃圾邮件发送。它们通过要求...
在IT行业中,验证码是一种...通过提供的文件,我们可以推断这是一个完整的解决方案,包括验证码生成脚本、使用说明以及字体管理工具。在实际开发中,这样的验证码系统可以显著提升网站的安全性,防止恶意自动化攻击。
综上所述,Node.js中使用captchapng模块生成图片验证码是一个实用且有效的解决方案,尤其适合那些对图片验证码要求不高,且希望简化开发流程的项目。同时,也期待Node.js社区能够继续成长,填补更多当前所缺失的库和...
描述中的“js验证码插件”指的是使用JavaScript编写的轻量级验证码解决方案,它通常包含几个关键组件: - **生成器**:生成随机字符串并转化为图像。 - **渲染器**:在HTML页面上展示验证码图像。 - **验证器**...
综上所述,这个压缩包可能包含了一个完整的图片验证码解决方案,从后端的验证码生成逻辑到前端的显示和验证。开发者可以通过研究这些文件,学习如何在.NET环境中创建自定义的、高效且安全的图片验证码系统,提升其...
在ASP(Active Server Pages)这种经典的服务器端脚本语言中实现汉字图片验证码,可以增加网站的安全性,因为汉字的多样性和复杂性增加了识别的难度,从而有效阻止恶意攻击。 在ASP中实现汉字图片验证码,主要涉及...
在这个Python实现的项目中,我们将深入探讨旋转验证码的生成与识别技术。 首先,生成旋转验证码涉及到以下几个关键技术点: 1. **随机生成字符**:验证码通常由随机选择的字母和数字组成,Python的`random`库可以...
在ASP.NET中实现图片验证码,主要涉及到以下几个关键知识点: 1. **生成随机字符串**:首先,我们需要创建一个包含随机字母和数字的字符串。这通常通过`Random`类和字符数组实现,确保每次请求时生成的字符串都是...
总结,Java JCaptcha验证码框架为开发者提供了一种高效且易于集成的验证码解决方案。通过理解和使用JCaptcha,不仅可以增强网站的安全性,还可以为用户提供良好的交互体验。在实际项目中,根据具体需求进行配置和...
本文将深入探讨如何使用PHP创建一个实用的图片验证码,包括其功能、实现原理以及解决可能出现的问题。 首先,我们要理解图片验证码的基本原理。它通过生成随机字符并以图像形式显示,同时添加干扰线和噪点来增加...
标题中的"asp生成验证码图片"指的是使用ASP技术来创建一个能够自动生成GIF格式的验证码图片的功能。这种功能对于防止垃圾邮件、恶意注册等网络安全问题至关重要。GIF是一种支持动画和透明度的图像格式,尽管现代Web...
总的来说,这个C#验证码程序结合了图像处理、随机数生成和WinForm界面设计等多个技术点,提供了一种有效且可自定义的验证码解决方案。通过理解并实践这样的项目,开发者可以提升在图形编程、安全性和用户体验设计...
在IT行业中,验证码是一种常见的安全机制,用于防止自动化的机器人或恶意软件进行非法操作,如批量注册...了解验证码的生成原理和实现方式,有助于在遇到类似需求时快速构建自己的解决方案,或者优化现有的验证码系统。
综上所述,这个压缩包提供了一套完整的Java图片验证码解决方案,从生成到验证,覆盖了验证码生命周期的全过程。对于开发人员来说,理解并应用这些代码可以帮助他们在自己的项目中快速实现验证码功能,提高系统的安全...
在本项目中,我们关注的是一个PHP类库,用于生成图片验证码并提供语音验证码功能。这个类库名为"Securimage",它是一个强大的开源解决方案,支持多种安全特性。 Securimage 是一个广泛使用的PHP CAPTCHA...
对于这个验证码生成类,readme.md可能会详细解释如何配置字体目录、如何引入类文件、示例代码以及可能出现的问题和解决方案。 通过以上方法,我们可以构建一个具有较高安全性的PHP验证码生成类,有效防止自动化攻击...