`
myharmony
  • 浏览: 108141 次
  • 性别: Icon_minigender_1
  • 来自: 中山市
社区版块
存档分类
最新评论

图片验证码

阅读更多
第一步:创建一个Servlet文件
//数字随机码
public class generateCode extends HttpServlet {
private static final long serialVersionUID = 5039673797977591965L;

protected void doGet(HttpServletRequest req, HttpServletResponse resp)
throws ServletException, IOException {
processRequest(req, resp);
}

protected void doPost(HttpServletRequest req, HttpServletResponse resp)
throws ServletException, IOException {
processRequest(req, resp);
}

public void processRequest(HttpServletRequest request,
HttpServletResponse response) throws IOException {
response.setContentType("11.gif"); //要设定好一个图片
response.setHeader("Pragma", "No-cache");
response.setHeader("Cache-Control", "no-cache");
response.setDateHeader("Expires", 0);
HttpSession session = request.getSession();
int width = 80, height = 20;
BufferedImage image = new BufferedImage(width, height,
BufferedImage.TYPE_INT_RGB);
Graphics g = image.getGraphics();
Random random = new Random();
g.setColor(getRandColor(200, 250));
g.fillRect(0, 0, width, height);

g.setFont(new Font("Times New Roman", Font.PLAIN, 18));
g.setColor(getRandColor(160, 200));
for (int i = 0; i < 155; i++) {
int x = random.nextInt(width);
int y = random.nextInt(height);
int xl = random.nextInt(12);
int yl = random.nextInt(12);
g.drawLine(x, y, x + xl, y + yl);
}

String sRand = "";
for (int i = 0; i < 6; i++) {
String rand = String.valueOf(random.nextInt(10));
sRand += rand;
g.setColor(new Color(20 + random.nextInt(110), 20 + random
.nextInt(110), 20 + random.nextInt(110)));
g.drawString(rand, 13 * i + 6, 16);
}
session.setAttribute("rand", sRand);
g.dispose();
ServletOutputStream responseOutputStream = response.getOutputStream();
ImageIO.write(image, "JPEG", responseOutputStream);
responseOutputStream.flush();
responseOutputStream.close();
}

Color getRandColor(int fc, int bc) {
Random random = new Random();
if (fc > 255)
fc = 255;
if (bc > 255)
bc = 255;
int r = fc + random.nextInt(bc - fc);
int g = fc + random.nextInt(bc - fc);
int b = fc + random.nextInt(bc - fc);
return new Color(r, g, b);
}
}

第二步 设置web.xml

        <servlet>
<servlet-name>showImgCode</servlet-name>
<servlet-class>generateCode </servlet-class>
</servlet>
<servlet-mapping>
<servlet-name>showImgCode</servlet-name>
<url-pattern>/11.GIF</url-pattern>
</servlet-mapping>

第三步 创建相应的JSP
index.jsp
<%@ page contentType="text/html;charset=gb2312"%>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<head>
<title>认证码输入页面</title>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312">
<META HTTP-EQUIV="Pragma" CONTENT="no-cache">
<META HTTP-EQUIV="Cache-Control" CONTENT="no-cache">
<META HTTP-EQUIV="Expires" CONTENT="0">

<script language="JavaScript">
          function myrefresh()
          {
            window.location.reload();
          }
      </script>
</head>
<body>
<form method=post action="check.jsp">
<table>
<tr>
<td align=left>
系统产生的认证码:
</td>
<td>
<img border=0 src="11.GIF">
<input type="button" value="看不清,在换一张" onclick="myrefresh()">
</td>
</tr>
<tr>
<td align=left>
输入上面的认证码:
</td>
<td>
<input type=text name=rand maxlength=6 value="">
</td>
</tr>
<tr>
<td colspan=2 align=center>
<input type=submit value="提交检测">
</td>
</tr>
</table>
</form>
</body>
</html>

Check.jsp
<%@ page contentType="text/html; charset=gb2312" language="java"
errorPage=""%>
<html>
<head>
<title>认证码验证页面</title>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312">
<META HTTP-EQUIV="Pragma" CONTENT="no-cache">
<META HTTP-EQUIV="Cache-Control" CONTENT="no-cache">
<META HTTP-EQUIV="Expires" CONTENT="0">
</head>
<body>
<%
String rand = (String) session.getAttribute("rand");
String input = request.getParameter("rand");
%>
系统产生的认证码为:
<%=rand%><br>
您输入的认证码为:
<%=input%><br>
<br>
<%
if (rand.equals(input)) {
%>
<font color=green>输入相同,认证成功!</font>
<%
} else {
%>
<font color=red>输入不同,认证失败!</font>
<%
}
%>
</body>
</html>
==================
长生字符和数据的验证码


public class CharactorCode extends HttpServlet {
private static final long serialVersionUID = 4347521091342882490L;
private Font mFont = new Font("Arial Black", Font.PLAIN, 16);

public void init() throws ServletException {
super.init();
}

Color getRandColor(int fc, int bc) {
Random random = new Random();
if (fc > 255)
fc = 255;
if (bc > 255)
bc = 255;
int r = fc + random.nextInt(bc - fc);
int g = fc + random.nextInt(bc - fc);
int b = fc + random.nextInt(bc - fc);
return new Color(r, g, b);
}

public void service(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
response.setHeader("Pragma", "No-cache");
response.setHeader("Cache-Control", "no-cache");
response.setDateHeader("Expires", 0);
response.setContentType("11.gif");

int width = 100, height = 18;
BufferedImage image = new BufferedImage(width, height,
BufferedImage.TYPE_INT_RGB);

Graphics g = image.getGraphics();
Random random = new Random();
g.setColor(getRandColor(200, 250));
g.fillRect(1, 1, width - 1, height - 1);
g.setColor(new Color(102, 102, 102));
g.drawRect(0, 0, width - 1, height - 1);
g.setFont(mFont);

g.setColor(getRandColor(160, 200));
for (int i = 0; i < 155; i++) {
int x = random.nextInt(width - 1);
int y = random.nextInt(height - 1);
int xl = random.nextInt(6) + 1;
int yl = random.nextInt(12) + 1;
g.drawLine(x, y, x + xl, y + yl);
}
for (int i = 0; i < 70; i++) {
int x = random.nextInt(width - 1);
int y = random.nextInt(height - 1);
int xl = random.nextInt(12) + 1;
int yl = random.nextInt(6) + 1;
g.drawLine(x, y, x - xl, y - yl);
}

String sRand = "";
for (int i = 0; i < 6; i++) {
String tmp = getRandomChar();
sRand += tmp;
g.setColor(new Color(20 + random.nextInt(110), 20 + random
.nextInt(110), 20 + random.nextInt(110)));
g.drawString(tmp, 15 * i + 10, 15);
}

HttpSession session = request.getSession(true);
session.setAttribute("rand", sRand);
g.dispose();
ImageIO.write(image, "JPEG", response.getOutputStream());
}

private String getRandomChar() {
int rand = (int) Math.round(Math.random() * 2);
long itmp = 0;
char ctmp = '\u0000';
switch (rand) {
case 1:
itmp = Math.round(Math.random() * 25 + 65);
ctmp = (char) itmp;
return String.valueOf(ctmp);
case 2:
itmp = Math.round(Math.random() * 25 + 97);
ctmp = (char) itmp;
return String.valueOf(ctmp);
default:
itmp = Math.round(Math.random() * 9);
return String.valueOf(itmp);
}
}
}
分享到:
评论

相关推荐

    图片验证码资源ZIP格式下载

    在本资源中,你将获得100张图片验证码的ZIP格式下载,这些图片可以用于训练机器学习模型,帮助理解验证码识别的挑战并提升相关算法的性能。 图片验证码通常包含扭曲的字母或数字,设计目的是让人类容易识别但机器...

    js验证码验证码插件,简单易用、图片验证码,附demo

    本篇文章将详细探讨基于JavaScript的验证码插件,特别是针对“js验证码插件,简单易用,图片验证码”的主题,以及如何通过附带的示例(demo)快速上手。 1. **JavaScript验证码原理** JavaScript验证码通常包含两...

    jmeter识别图片验证码的包

    而当涉及到需要登录或者交互过程中有图片验证码的场景时,JMeter默认是无法直接处理的。本压缩包“jmeter识别图片验证码的包”提供了一种解决方案,即利用OCR(Optical Character Recognition,光学字符识别)技术来...

    图片验证码9000多张

    图片验证码9000多张 图片验证码9000多张 图片验证码9000多张

    JAVA图片验证码 图片验证码

    JAVA图片验证码 图片验证码JAVA图片验证码 图片验证码JAVA图片验证码 图片验证码JAVA图片验证码 图片验证码JAVA图片验证码 图片验证码JAVA图片验证码 图片验证码

    Java实现点击文字验证码与拖动/滑动图片验证码(源码+demo+单元测试+实现思路)

    1.部署步骤 1.1 100%可生产使用. 1.2 导入到idea时候选择maven项目 1.3 修改demo里面子项目resources/application.yml的redis... 4.2拖动图片验证码:https://blog.csdn.net/m0_38138879/article/details/117559456

    通用图片验证码识别 (大漠字库)

    《通用图片验证码识别技术解析与应用》 验证码(CAPTCHA)是一种网络安全机制,用于防止自动化的机器人程序进行恶意操作,如垃圾邮件发送、账号注册等。随着技术的发展,验证码的形式日益多样化,其中以图片验证码...

    java解析图片验证码

    java解析图片验证码

    使用python+robot framework识别图片验证码

    本篇将详细讲解如何使用Python和Robot Framework相结合来识别图片验证码,以及如何利用PIL库进行图像处理,以及提到了一个用于识别验证码的第三方库——pytesser。 首先,让我们了解Python和Robot Framework的基本...

    【ASP.NET编程知识】Asp.net Web Api实现图片点击式图片验证码功能.docx

    总的来说,通过ASP.NET Web API实现点击式图片验证码功能,不仅提供了额外的安全层,还增加了用户体验的趣味性。这样的验证码实现需要考虑的因素包括文字的选择、颜色的随机性、位置的分配以及验证逻辑的实现,这些...

    vc++ 根据文字生成图片 文字图片验证码.zip

    "vc++ 根据文字生成图片 文字图片验证码.zip"是一个关于如何使用Visual C++(简称VC++)编程语言来创建文字图片验证码的项目。这个压缩包可能包含必要的源代码、文档和其他资源,帮助开发者了解和实现验证码生成的...

    图片验证码的例子

    标题中的“图片验证码的例子”指的是一个用于网络安全的身份验证机制,它通常由一组随机生成的字母、数字或符号组成,以图像形式展示,用户需要输入看到的验证码内容来证明他们是人类而不是自动化程序。这种方式能...

    一个asp.net图片验证码

    ASP.NET 图片验证码是一种用于验证用户身份的安全机制,它通过生成随机的图像和文本组合来防止自动化的机器人或恶意软件进行非法操作。这种验证码的主要目的是防止垃圾邮件、自动注册和恶意登录尝试。在这个特定的...

    asp.net 图片验证码

    ASP.NET 图片验证码是一种用于网络安全的身份验证机制,它在网页上以图像的形式显示一组随机生成的字符,用户需要输入这些字符以证明他们不是自动化程序。这种验证码的主要目的是防止机器人、爬虫和其他自动化工具...

    html图片验证码组件

    HTML图片验证码组件是一种用于网络安全的身份验证机制,它通过在网页上显示一幅随机生成的图片,其中包含一组可读的字符,然后要求用户输入所见字符来确认他们不是自动化程序。这种技术广泛应用于防止机器人和自动...

    asp.net图片验证码

    ASP.NET 图片验证码是一种用于防止自动化程序(如机器人)恶意操作的网络安全机制。它通过生成随机的、由字母和数字组成的图像,要求用户在输入框中输入所见内容,以此来验证用户是真实的人而非机器。这个过程被称为...

    asp汉字图片验证码

    ASP汉字图片验证码是一种常见的安全验证技术,用于防止自动化程序(如机器人)对网站进行非法操作,如注册、登录或发布内容。在ASP(Active Server Pages)这种经典的服务器端脚本语言中实现汉字图片验证码,可以...

    利用jsp生成图片验证码

    在Web开发中,图片验证码(CAPTCHA)是一种广泛使用的安全机制,用于防止自动机器人或恶意软件进行非法操作,如注册、登录或者提交表单。在本主题“利用jsp生成图片验证码”中,我们将探讨如何在JavaServer Pages ...

    ASP.NET图片验证码程序(含调用实例)

    ASP.NET图片验证码程序是一种用于网络安全的身份验证机制,它主要用于防止自动化的机器人或恶意脚本进行非法操作,如垃圾邮件提交、刷票等。这个程序利用C#编程语言编写,结合了图像处理技术来生成随机的、难以被...

Global site tag (gtag.js) - Google Analytics