- 浏览: 66391 次
- 性别:
- 来自: 上海
文章分类
最新评论
为了防止某些用户使用软件进行登录和发布信息,很多网站在用户登录或者发布信息时,都要求用户输入验证码,验证码通常是以一幅图片的形式显示的,用户按照图片中显示的数字或字母依次输入,服务器端将对用户的输入和验证码进行比较,以判断用户是否经过校验.由于验证码是随机产生的,自动发布信息的软件无法知道每次产生的验证码,也就无法自动发布信息了.
1.引入以下类
package util;
import java.awt.Color;
import java.awt.Font;
import java.awt.Graphics2D;
import java.awt.image.BufferedImage;
import java.io.IOException;
import java.io.OutputStream;
import java.util.Random;
import javax.imageio.ImageIO;
public class RandomUtils {
private static Random random;
private static char[] c;//存放a-z,A-Z,0-9,62个字符,在随机生成key时使用
private static final int Length=62;//c[]的长度是62
static {
init();
}
private static void init() {
random=new Random(System.currentTimeMillis());
c=new char[Length];
int i=0;
for(char b='a';b<='z';b++) {
c[i++]=b;
}
for(char b='A';b<='Z';b++) {
c[i++]=b;
}
for(char b='0';b<='9';b++) {
c[i++]=b;
}
}
public static int nextInt() {
return random.nextInt();
}
public static int nextInt(int n) {
return random.nextInt(n);
}
/**
* 生成keyLength位随机字符串,字符串只包含a-z,A-Z,0-9
* @return
*/
public static String generateKey(int keyLength) {
StringBuffer buffer=new StringBuffer();
int index;
for(int i=0;i<keyLength;i++) {
index=random.nextInt(Length);
buffer.append(c[index]);
}
return buffer.toString();
}
/**
* 生成32位随机字符串,字符串只包含a-z,A-Z,0-9
* @return
*/
public static String generateKey() {
return generateKey(32);
}
/**
* 输出验证码图片
* @param os 输出流
* @param code 图片上的验证码
* @param width 图片宽度
* @param height 图片高度
* @throws IOException
*/
public static void generateVerifyCode(OutputStream os,String code,int width,int height) throws IOException {
BufferedImage buffImg=new BufferedImage(width,height,BufferedImage.TYPE_INT_BGR);
Graphics2D g=buffImg.createGraphics();
g.setColor(Color.WHITE);
g.fillRect(0,0,width,height);
Font f Font("Times New Roman",Font.PLAIN,18);
g.setFont(font);
g.setColor(Color.BLACK);
g.drawRect(0,0,width-1,height-1);
g.setColor(new Color(192,192,192));
int x,y,x1,y1;
for(int i=0;i<(width+height);i++) {
x=random.nextInt(width);
y=random.nextInt(height);
x1=random.nextInt(12);
y1=random.nextInt(12);
g.drawLine(x,y,x+x1,y+y1);
}
int red=0,green=0,blue=0;
for(int i=0,n=code.length();i<n;i++) {
red=random.nextInt(110);
green=random.nextInt(110);
blue=random.nextInt(110);
g.setColor(new Color(red,green,blue));
g.drawString(code.charAt(i)+"",13*i+6,16);
}
ImageIO.write(buffImg,"jpeg",os);
os.flush();
}
}
2.创建一Servlet,样例代码如下
package servlet;
import java.io.IOException;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import util.RandomUtils;
public class RandomCodeServlet extends HttpServlet {
public void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
response.setHeader("Pragma","no-cache");
response.setHeader("Cache-Control","no-cache");
response.setDateHeader("Expries",0);
response.setContentType("image/jpeg");
String code=RandomUtils.generateKey(4); //生成4个随机字符
RandomUtils.generateVerifyCode(response.getOutputStream(),code,60,20); //生成验证码图片
//request.getSession().setAttribute("verifyCode",code);
response.getOutputStream().flush();
response.getOutputStream().close();
}
public void doPost(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
doGet(request,response);
}
}
该Servlet可以根据自己的业务需求变化而变化,例如将code设置到session中,待客户端提交时,到session中取出code,与客户端提交过来的验证码比较,如果相同,则继续其它业务逻辑,否则退出.
3.在web.xml里配制该Servlet
<servlet>
<servlet-name>RandomCodeServlet</servlet-name>
<servlet-class>servlet.RandomCodeServlet</servlet-class>
</servlet>
<servlet-mapping>
<servlet-name>RandomCodeServlet</servlet-name>
<url-pattern>/randomCode</url-pattern>
</servlet-mapping>
4.新建一HTML文件,在body标签中引入如下代码
<img src="randomCode" id="randomImage"/><a href="javascript:" onclick='return switchImage();'>看不清,换一张!</a>
<script language='javascript'>
var imgCount=1;
function switchImage() {
var image=document.getElementById('randomImage');
image.src="randomCode?imgCount="+imgCount++;
return false;
}
</script>
这里的randomCode和web.xml的url-pattern设置是一样的,imgCount一定要加上,它不起什么业务逻辑作用,只是用于改变src属性的值,并告诉浏览器,该图片的src属性值变了,要浏览器去重新加载该图片,如果<img>的src属性没有变,浏览器是不会去重新加载该图片的.
5.启动服务器,浏览刚创建的HTML文件,OK了吧!
1.引入以下类
package util;
import java.awt.Color;
import java.awt.Font;
import java.awt.Graphics2D;
import java.awt.image.BufferedImage;
import java.io.IOException;
import java.io.OutputStream;
import java.util.Random;
import javax.imageio.ImageIO;
public class RandomUtils {
private static Random random;
private static char[] c;//存放a-z,A-Z,0-9,62个字符,在随机生成key时使用
private static final int Length=62;//c[]的长度是62
static {
init();
}
private static void init() {
random=new Random(System.currentTimeMillis());
c=new char[Length];
int i=0;
for(char b='a';b<='z';b++) {
c[i++]=b;
}
for(char b='A';b<='Z';b++) {
c[i++]=b;
}
for(char b='0';b<='9';b++) {
c[i++]=b;
}
}
public static int nextInt() {
return random.nextInt();
}
public static int nextInt(int n) {
return random.nextInt(n);
}
/**
* 生成keyLength位随机字符串,字符串只包含a-z,A-Z,0-9
* @return
*/
public static String generateKey(int keyLength) {
StringBuffer buffer=new StringBuffer();
int index;
for(int i=0;i<keyLength;i++) {
index=random.nextInt(Length);
buffer.append(c[index]);
}
return buffer.toString();
}
/**
* 生成32位随机字符串,字符串只包含a-z,A-Z,0-9
* @return
*/
public static String generateKey() {
return generateKey(32);
}
/**
* 输出验证码图片
* @param os 输出流
* @param code 图片上的验证码
* @param width 图片宽度
* @param height 图片高度
* @throws IOException
*/
public static void generateVerifyCode(OutputStream os,String code,int width,int height) throws IOException {
BufferedImage buffImg=new BufferedImage(width,height,BufferedImage.TYPE_INT_BGR);
Graphics2D g=buffImg.createGraphics();
g.setColor(Color.WHITE);
g.fillRect(0,0,width,height);
Font f Font("Times New Roman",Font.PLAIN,18);
g.setFont(font);
g.setColor(Color.BLACK);
g.drawRect(0,0,width-1,height-1);
g.setColor(new Color(192,192,192));
int x,y,x1,y1;
for(int i=0;i<(width+height);i++) {
x=random.nextInt(width);
y=random.nextInt(height);
x1=random.nextInt(12);
y1=random.nextInt(12);
g.drawLine(x,y,x+x1,y+y1);
}
int red=0,green=0,blue=0;
for(int i=0,n=code.length();i<n;i++) {
red=random.nextInt(110);
green=random.nextInt(110);
blue=random.nextInt(110);
g.setColor(new Color(red,green,blue));
g.drawString(code.charAt(i)+"",13*i+6,16);
}
ImageIO.write(buffImg,"jpeg",os);
os.flush();
}
}
2.创建一Servlet,样例代码如下
package servlet;
import java.io.IOException;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import util.RandomUtils;
public class RandomCodeServlet extends HttpServlet {
public void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
response.setHeader("Pragma","no-cache");
response.setHeader("Cache-Control","no-cache");
response.setDateHeader("Expries",0);
response.setContentType("image/jpeg");
String code=RandomUtils.generateKey(4); //生成4个随机字符
RandomUtils.generateVerifyCode(response.getOutputStream(),code,60,20); //生成验证码图片
//request.getSession().setAttribute("verifyCode",code);
response.getOutputStream().flush();
response.getOutputStream().close();
}
public void doPost(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
doGet(request,response);
}
}
该Servlet可以根据自己的业务需求变化而变化,例如将code设置到session中,待客户端提交时,到session中取出code,与客户端提交过来的验证码比较,如果相同,则继续其它业务逻辑,否则退出.
3.在web.xml里配制该Servlet
<servlet>
<servlet-name>RandomCodeServlet</servlet-name>
<servlet-class>servlet.RandomCodeServlet</servlet-class>
</servlet>
<servlet-mapping>
<servlet-name>RandomCodeServlet</servlet-name>
<url-pattern>/randomCode</url-pattern>
</servlet-mapping>
4.新建一HTML文件,在body标签中引入如下代码
<img src="randomCode" id="randomImage"/><a href="javascript:" onclick='return switchImage();'>看不清,换一张!</a>
<script language='javascript'>
var imgCount=1;
function switchImage() {
var image=document.getElementById('randomImage');
image.src="randomCode?imgCount="+imgCount++;
return false;
}
</script>
这里的randomCode和web.xml的url-pattern设置是一样的,imgCount一定要加上,它不起什么业务逻辑作用,只是用于改变src属性的值,并告诉浏览器,该图片的src属性值变了,要浏览器去重新加载该图片,如果<img>的src属性没有变,浏览器是不会去重新加载该图片的.
5.启动服务器,浏览刚创建的HTML文件,OK了吧!
发表评论
-
自定义xsd扩展
2018-12-24 11:43 1231扩展xsd很简单,官方文档送上:https://docs.s ... -
cglib
2017-06-09 17:54 365import net.sf.cglib.core.Nami ... -
最近学习经验总结二
2017-03-02 15:50 0集合框架: Collection L ... -
最近学习经验总结一
2017-03-02 15:49 0java 基础(重点多线程,锁) ArrayList 数据 ... -
mysql乐观锁/悲观锁
2017-02-24 09:29 0http://chenzhou123520.iteye.co ... -
一致性hash
2017-02-23 19:47 0http://www.blogjava.net/hello-y ... -
单例模式写法之SingletonHolder
2017-02-20 11:16 1197public class SingleDemo { ... -
ThreadLocal源码分析一ThreadLocalMap类
2016-10-21 17:28 0接上文我们将到ThreadLocal基本相当于一个空壳,它 ... -
ThreadLocal源码分析一ThreadLocal类
2016-10-21 17:22 1002ThreadLocal类提供线程局部变量。这些变量和其他普 ... -
阿里巴巴druid源码分析之 filter-chain设计模式
2016-09-20 18:18 7691druid是号称目前最好的java数据库连接池,温少写的代 ... -
ServiceLoader
2016-09-20 15:27 0https://my.oschina.net/hanzhank ... -
驼峰和下划线互转
2016-08-24 11:38 1316public class HumpLineUtil { ... -
java Eclipse配合开启远程debug
2016-08-11 11:18 482远程机器jar方式启动的时候需要指定dubug参数 ... -
java锁之wait,notify(wait会释放锁,notify仅仅只是通知,不释放锁)
2016-07-29 09:40 9364wait是指在一个已经进入了同步锁的线程内,让自己暂 ... -
java锁之CyclicBarrier(互相等待,直到大家都做完,一起开始下面)
2016-07-28 14:43 856参考文章:http://blog.csdn.net/lmc ... -
java锁之CountDownLatch(等待最后一个完成)
2016-07-28 11:19 2036线程同步工具,允许一个线程(或者多个线程)等待其他所有线程 ... -
java锁之Semaphore(信号量,限制并发数量)
2016-07-28 11:17 2077Semaphore也是一个线程同步的辅助类,可以维护当前访 ... -
内部类和final关键字
2016-07-28 11:08 457首先,内部类被编译的时候会生成一个单独的内部类的.class ... -
visitor设计模式
2016-06-29 14:09 324visitor设计模式 visitor设计模式的思 ... -
asm字节码生成技术,cglib
2016-06-29 11:25 642相关技术blog class文件解析: https:/ ...
相关推荐
获取验证码图片,不是识别验证码!获取验证码图片,不是识别验证码!获取验证码图片,不是识别验证码!获取验证码图片,不是识别验证码!获取验证码图片,不是识别验证码!获取验证码图片,不是识别验证码!获取验证码图片,不是...
验证码是网络安全领域中的一种常见机制,用于防止自动化程序(如机器人)进行非法操作,例如恶意注册、刷票等。在Web开发中,JavaScript验证码插件是实现这一功能的便捷工具,尤其对于前端开发者来说,它们提供了...
验证码是网络安全领域中的一种常见机制,用于防止自动化程序(如机器人)进行非法操作,例如注册、登录或提交表单。本篇文章将详细讨论验证码的基本原理,以及如何使用Java实现简单的验证码破解方法。请注意,了解...
看很多人都在找asp 验证码 asp 随机验证 我收集了四个非常优秀的ASP随机验证码,非常好用,分别为: Asp纯数字随机验证码程序 (5.98 kb) Asp数字及字母组合验证码程序(5.98 kb) Asp纯字母验证码程序.zip (5.98 kb ...
验证码是Web应用中常见的一种安全机制,用于防止自动化的机器人或者恶意软件进行非法操作,比如注册、登录等。本项目提供了生成验证码的功能,并且在Java后台处理了验证码的验证过程,确保用户输入的验证码与系统...
在网络安全领域,登录验证码是一种广泛使用的安全机制,用于防止恶意自动化程序(如机器人)未经授权地访问或操作用户账户。本文将深入探讨“gif动态登录验证码”这一特定的技术,以及它如何增强网站的安全性。 ...
本资料主要探讨了四种类型的行为验证码:滑块验证码、点选验证码、行为验证码以及旋转验证码,特别是滑动验证码。 1. **滑块验证码**:滑块验证码是目前常见的验证码形式,用户需要将一个滑块拖动到正确的位置以...
在实际部署中,开发者需要注意防刷机制,如验证码的刷新频率不宜过高,以免给正常用户带来不便,同时也可以加入验证码刷新的按钮,允许用户在看不清楚时刷新验证码。 最后,文件内容强调了layUI的验证码实现是使用...
今天专门给大家来聊聊验证码的问题,一般的情况下遇到验证码我们可以都可以找开发去帮忙解决,关闭验证码,或者给一个万能的验证码!那么如果开发不提供帮助的话,我们自己有没有办法来处理这些验证码的问题呢?答案...
在.NET开发中,验证码是一种常见的安全机制,用于防止自动化脚本或机器人进行恶意操作,如批量注册、频繁登录等。创建一个复杂的验证码可以提高网站的安全性,减少非法攻击的可能性。本教程将详细介绍如何在.NET中...
在网络安全和反爬虫技术领域,验证码是一种常用的方法,用于防止自动化的机器人程序对网站进行恶意操作,如数据抓取或滥用服务。本资源包针对验证码反爬提供了相关的工具和资料,主要涉及到“超级鹰打码平台”以及...
在Android应用开发中,验证码(CAPTCHA)是一种重要的安全机制,用于验证用户是人类而非自动程序。本篇文章将深入探讨如何在Android平台上实现验证码功能,包括自定义控件的创建和验证码的生成与验证。 首先,...
验证码识别技术是网络安全中一种常见的身份验证手段,用于防止恶意自动化程序(如机器人)进行非法操作。汉字验证码识别尤其具有挑战性,因为它涉及到中文字符的多样性以及图像处理的复杂性。下面将详细介绍图像分割...
在安卓应用开发中,"安卓发送验证码倒计时效果和自动获取验证码并填充"是一个常见的功能,主要用于用户注册、登录或修改重要信息时的身份验证。这个功能涉及到多个关键知识点,包括网络请求、短信监听、UI更新以及...
3. **国际短信验证码**:验证码通常以数字或字母的形式发送到用户的手机,用户需要在应用或网站上输入接收到的验证码以完成身份验证。由于是国际服务,ihuyi的验证码支持全球范围内的手机号码,适应跨国应用的需求。...
ASP.NET动态验证码是一种用于验证用户身份的安全机制,广泛应用于网页登录、注册和其他涉及用户交互的安全场景。它通过生成随机的图像和文字组合,要求用户在输入框中输入看到的字符,以此来防止自动化的机器人或者...
和验证码相关的图片数据集 数据说明: ·图像:包含PNG格式的验证码图像的文件夹。 ·Labels:包含两列的CSV文件:image_filename和文本。imagefilename对应于CAPTCHA图像的文件名,text包含CAPTCHA中描述的字母数字文本...
验证码识别技术是信息安全领域中的一个重要话题,特别是在防止自动化程序(如机器人)滥用服务时。VB,全称Visual Basic,是一种由Microsoft开发的编程环境,它提供了丰富的功能来创建图形用户界面和处理各种任务,...
验证码识别技术是信息安全领域中的一个重要组成部分,主要用于防止自动化的机器人程序进行恶意操作,如批量注册、刷票等。本资源“完美验证码识别系统V3.2.1.zip”提供了一个通用的验证码识别组件,适用于多种验证码...