public class OnLineImage {
// //验证码图片中可以出现的字符集,可根据需要修改
// private char mapTable[]={
// 'a','b','c','d','e','h',
// 'A','B','C','D','E','F',
// 'j','k','m','n','p','q',
// 'J','K','M','N','P','Q',
// 'r','s','t','u','v','w',
// 'R','S','T','U','V','W',
// 'x','y','z','X','Y','Z',
// '2','3','4','5','6','7',
// '8','9'
// };
//
// 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 random = new Random();
// for(int i=0; i<10; i++ ) {
// int x = random.nextInt(width);
// int y = random.nextInt(height);
// g.drawOval(x, y, 1, 1);
// }
// //释放图形上下文
// g.dispose();
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 String getCertPic(OutputStream os) {
// 在内存中创建图象
int width = 60, height = 20;
BufferedImage image = new BufferedImage(width, height, BufferedImage.TYPE_INT_RGB);
// 获取图形上下文
Graphics g = image.getGraphics();
//生成随机类
Random random = new Random();
// 设定背景色
g.setColor(this.getRandColor(200,250));
g.fillRect(0, 0, width, height);
//设定字体
g.setFont(new Font("Times New Roman",Font.PLAIN,18));
//画边框
//g.setColor(new Color());
//g.drawRect(0,0,width-1,height-1);
// 随机产生155条干扰线,使图象中的认证码不易被其它程序探测到
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);
}
// 取随机产生的认证码(4位数字)
String sRand="";
for (int i=0;i<4;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);
}
// 图象生效
g.dispose();
try{
//输出图像到页面
ImageIO.write(image, "JPEG", os);
}catch(IOException e) {
return "";
}
return sRand;
}
}
action :
public class Image extends Action{
public ActionForward execute(ActionMapping mapping, ActionForm form,
HttpServletRequest request, HttpServletResponse response)
throws Exception {
HttpSession session = request.getSession();
session.removeAttribute("imagestr");
OnLineImage image = new OnLineImage();
String str = image.getCertPic(response.getOutputStream());
session.setAttribute("sRand", str);
return null;
}
}
验证:
public class ValidateCode extends Action{
public ActionForward execute(ActionMapping mapping, ActionForm form,
HttpServletRequest request, HttpServletResponse response)
throws Exception {
PrintWriter out = response.getWriter();
HttpSession session = request.getSession();
String code = (String) session.getAttribute("sRand");
String code1 = request.getParameter("code");
if(code.equals(code1)) {
out.print("1");
}else {
out.print("0");
}
return null;
}
}
jsp 显示验证码:
<img id="code" border="0" src="/hereImage.do" alt="验证码" />
更换验证码:
function reloadCode(){
$("code").src = path+"image.do?" + Math.random();
}
//----------------------------------------------------------------------------------------------
public class SeccodeBuild extends HttpServlet {
private static final long serialVersionUID = -205545450335033053L;
private String randStrs = "ABCDEFGHIGKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789";
public void destroy() {
super.destroy();
}
public void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
getImage(request, response);
}
public void doPost(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
doGet(request, response);
}
public void init() throws ServletException {
}
@SuppressWarnings("unchecked")
public void getImage(HttpServletRequest request,HttpServletResponse response) throws ServletException, IOException {
Map<String,String> settingMap = ForumInit.settings;
String seccodedataString = settingMap.get("seccodedata");
Map<String,Object> seccodedata = ((DataParse)BeanFactory.getBean("dataParse")).characterParse(seccodedataString, false);
String widthString = String.valueOf(seccodedata.get("width")); //宽度
String heightString = String.valueOf(seccodedata.get("height")); //高度
int width = Integer.parseInt(widthString);
int height = Integer.parseInt(heightString);
int fontSize = width/4; //字体大小
int wordPlace = (height/2+fontSize/3); //字符替换
BufferedImage image = new BufferedImage(width, height,BufferedImage.TYPE_INT_RGB);//构造一个类型为预定义图像类型之一的 BufferedImage
Graphics g = image.getGraphics(); //可用于绘制此图像
g.setColor(getRandColor(200, 250)); //将此图形上下文的当前颜色设置为指定颜色
g.fillRect(0, 0, width, height); //填充指定的矩形
g.setFont(new Font("宋体", Font.PLAIN, fontSize)); //将此图形上下文的字体设置为指定字体
g.setColor(getRandColor(160, 200));
for (int i = 0; i < 155; i++) {
int x = Common.rand(width);
int y = Common.rand(height);
int xl = Common.rand(width);
int yl = Common.rand(height);
g.drawLine(x, y , xl, yl); //在此图形上下文的坐标系中,使用当前颜色在点 (x1, y1) 和 (x2, y2) 之间画一条线。
}
int randLen = 4;
StringBuffer sRand = new StringBuffer(randLen);
for (int i = 0; i < randLen; i++) {
String rand = String.valueOf(randStrs.charAt(Common.rand(61)));
sRand.append(rand);
g.setColor(new Color(20 + Common.rand(110), 20 + Common.rand(110), 20 + Common.rand(110)));
g.drawString(rand, fontSize * i + fontSize/4, wordPlace);//使用此图形上下文的当前字体和颜色绘制由指定 string 给定的文本
}
g.dispose();
HttpSession session = request.getSession(true);
session.setAttribute("rand", sRand.toString());
ImageIO.write(image, "JPEG", response.getOutputStream());//使用支持给定格式的任意 ImageWriter 将一个图像写入 OutputStream
image=null;
}
private Color getRandColor(int fc, int bc) {
if (fc > 255)
fc = 255;
if (bc > 255)
bc = 255;
int r = fc + Common.rand(bc - fc);
int g = fc + Common.rand(bc - fc);
int b = fc + Common.rand(bc - fc);
return new Color(r, g, b);
}
}
分享到:
相关推荐
获取验证码图片,不是识别验证码!获取验证码图片,不是识别验证码!获取验证码图片,不是识别验证码!获取验证码图片,不是识别验证码!获取验证码图片,不是识别验证码!获取验证码图片,不是识别验证码!获取验证码图片,不是...
验证码是网络安全领域中的一种常见机制,用于防止自动化程序(如机器人)进行非法操作,例如恶意注册、刷票等。在Web开发中,JavaScript验证码插件是实现这一功能的便捷工具,尤其对于前端开发者来说,它们提供了...
验证码是网络安全领域中的一种常见机制,用于防止自动化程序(如机器人)进行非法操作,例如注册、登录或提交表单。本篇文章将详细讨论验证码的基本原理,以及如何使用Java实现简单的验证码破解方法。请注意,了解...
看很多人都在找asp 验证码 asp 随机验证 我收集了四个非常优秀的ASP随机验证码,非常好用,分别为: Asp纯数字随机验证码程序 (5.98 kb) Asp数字及字母组合验证码程序(5.98 kb) Asp纯字母验证码程序.zip (5.98 kb ...
验证码是Web应用中常见的一种安全机制,用于防止自动化的机器人或者恶意软件进行非法操作,比如注册、登录等。本项目提供了生成验证码的功能,并且在Java后台处理了验证码的验证过程,确保用户输入的验证码与系统...
本资料主要探讨了四种类型的行为验证码:滑块验证码、点选验证码、行为验证码以及旋转验证码,特别是滑动验证码。 1. **滑块验证码**:滑块验证码是目前常见的验证码形式,用户需要将一个滑块拖动到正确的位置以...
在网络安全领域,登录验证码是一种广泛使用的安全机制,用于防止恶意自动化程序(如机器人)未经授权地访问或操作用户账户。本文将深入探讨“gif动态登录验证码”这一特定的技术,以及它如何增强网站的安全性。 ...
在实际部署中,开发者需要注意防刷机制,如验证码的刷新频率不宜过高,以免给正常用户带来不便,同时也可以加入验证码刷新的按钮,允许用户在看不清楚时刷新验证码。 最后,文件内容强调了layUI的验证码实现是使用...
今天专门给大家来聊聊验证码的问题,一般的情况下遇到验证码我们可以都可以找开发去帮忙解决,关闭验证码,或者给一个万能的验证码!那么如果开发不提供帮助的话,我们自己有没有办法来处理这些验证码的问题呢?答案...
在.NET开发中,验证码是一种常见的安全机制,用于防止自动化脚本或机器人进行恶意操作,如批量注册、频繁登录等。创建一个复杂的验证码可以提高网站的安全性,减少非法攻击的可能性。本教程将详细介绍如何在.NET中...
在网络安全和反爬虫技术领域,验证码是一种常用的方法,用于防止自动化的机器人程序对网站进行恶意操作,如数据抓取或滥用服务。本资源包针对验证码反爬提供了相关的工具和资料,主要涉及到“超级鹰打码平台”以及...
在Android应用开发中,验证码(CAPTCHA)是一种重要的安全机制,用于验证用户是人类而非自动程序。本篇文章将深入探讨如何在Android平台上实现验证码功能,包括自定义控件的创建和验证码的生成与验证。 首先,...
验证码识别技术是网络安全中一种常见的身份验证手段,用于防止恶意自动化程序(如机器人)进行非法操作。汉字验证码识别尤其具有挑战性,因为它涉及到中文字符的多样性以及图像处理的复杂性。下面将详细介绍图像分割...
在安卓应用开发中,"安卓发送验证码倒计时效果和自动获取验证码并填充"是一个常见的功能,主要用于用户注册、登录或修改重要信息时的身份验证。这个功能涉及到多个关键知识点,包括网络请求、短信监听、UI更新以及...
3. **国际短信验证码**:验证码通常以数字或字母的形式发送到用户的手机,用户需要在应用或网站上输入接收到的验证码以完成身份验证。由于是国际服务,ihuyi的验证码支持全球范围内的手机号码,适应跨国应用的需求。...
ASP.NET动态验证码是一种用于验证用户身份的安全机制,广泛应用于网页登录、注册和其他涉及用户交互的安全场景。它通过生成随机的图像和文字组合,要求用户在输入框中输入看到的字符,以此来防止自动化的机器人或者...
和验证码相关的图片数据集 数据说明: ·图像:包含PNG格式的验证码图像的文件夹。 ·Labels:包含两列的CSV文件:image_filename和文本。imagefilename对应于CAPTCHA图像的文件名,text包含CAPTCHA中描述的字母数字文本...
验证码识别技术是信息安全领域中的一个重要话题,特别是在防止自动化程序(如机器人)滥用服务时。VB,全称Visual Basic,是一种由Microsoft开发的编程环境,它提供了丰富的功能来创建图形用户界面和处理各种任务,...
发送的验证码内容代码,已写好,直接添加按钮调用即可,无需营业执照,个人可用,无需任何资质,轻松实现短信验证码功能,无需理解底层原理,全部封装好,直接调用即可,已写中文注释,使用c#代码编写,可在任何支持...