- 浏览: 105695 次
- 性别:
- 来自: 天津
-
文章分类
最新评论
-
sqz10200:
...
urlrewrite 路径重写 -
侯上校:
Very Good !!!学习了……
tomcat jndi -
Rocket076:
简明易懂,学习了
java读取Excel -
captmjc:
myreligion 写道
引用(5)、record_buf ...
mysql性能优化的参数简介 -
mathgl:
xiaoZ5919 写道引用
(4)、max_connecti ...
mysql性能优化的参数简介
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); } }
发表评论
-
算法的Java实现
2011-06-02 17:05 856引用: http://www.java3z.com/cwbw ... -
页面表格成Execl
2011-06-02 14:47 969ExcleBuild.java//生成Execl所要的类 ... -
数据连接池
2010-05-26 16:53 682数据库 -
(mysql,sqlserver,orcal)数据连接
2010-05-14 10:44 965<?xml version="1.0" ... -
汉语转拼音
2010-05-12 08:12 828//汉语转拼音的方法 protected String ... -
dom和xas解析xml
2010-04-14 17:37 857xas 解析import java.io.FileIn ... -
数据连接池源理
2010-03-15 14:31 2000近年来,随着Internet/Intr ... -
jdbc DBUtils
2010-03-15 14:09 1108package jing.lian.kui.util; ... -
jdbc连mysql数据库
2010-02-23 15:10 915package cn.com.sohocat.util; ... -
读xml
2010-02-23 15:08 870/** * @#ConstantDAO.java * ... -
java 报表
2010-02-23 15:06 1298JavaReport-V3-Enterprise-Releas ... -
根椐ip得到地址
2010-02-23 14:59 687把QQWry.Dat放到WebRoot/WEB-INF下 就 ... -
MD5加密
2010-02-23 14:52 689package com.here.web.common; ... -
java图片验证码
2010-02-23 14:51 904package com.here.web.common; ... -
处理中文时的乱码问题
2010-02-23 14:49 758最近在做一个类似于百度的提示功能,可是遇到了dwr给后台传值是 ... -
jspsmart.upload
2010-02-23 14:48 982上传图1.jsp <table id=&q ... -
添加cookie最近浏览过的5职位
2010-02-23 14:47 780关键字: cookie if(document.all){ ... -
fckeditor 编辑器 web.xml配置
2010-02-23 14:44 817<servlet> <ser ... -
log4j.properties 配置
2010-02-23 14:43 746## log4j.rootLogger=error, cons ... -
cookie
2010-02-23 14:41 834public class Cookies { public ...
相关推荐
获取验证码图片,不是识别验证码!获取验证码图片,不是识别验证码!获取验证码图片,不是识别验证码!获取验证码图片,不是识别验证码!获取验证码图片,不是识别验证码!获取验证码图片,不是识别验证码!获取验证码图片,不是...
验证码是网络安全领域中的一种常见机制,用于防止自动化程序(如机器人)进行非法操作,例如恶意注册、刷票等。在Web开发中,JavaScript验证码插件是实现这一功能的便捷工具,尤其对于前端开发者来说,它们提供了...
验证码是网络安全领域中的一种常见机制,用于防止自动化程序(如机器人)进行非法操作,例如注册、登录或提交表单。本篇文章将详细讨论验证码的基本原理,以及如何使用Java实现简单的验证码破解方法。请注意,了解...
验证码识别数据集的下载与应用在当今互联网信息安全领域中占据着重要的地位。验证码,全称为“Completely Automated Public Turing test to tell Computers and Humans Apart”,其核心目的是区分计算机和人类用户,...
看很多人都在找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更新以及...
验证码(CAPTCHA)是一种用于验证用户是否为人类的在线安全技术。四字定长数英验证码数据集,正如其名,包含了一万个四个字符长度、混合数字和字母的验证码图片,这种类型的数据集广泛用于训练计算机视觉模型,尤其...
ASP.NET动态验证码是一种用于验证用户身份的安全机制,广泛应用于网页登录、注册和其他涉及用户交互的安全场景。它通过生成随机的图像和文字组合,要求用户在输入框中输入看到的字符,以此来防止自动化的机器人或者...
和验证码相关的图片数据集 数据说明: ·图像:包含PNG格式的验证码图像的文件夹。 ·Labels:包含两列的CSV文件:image_filename和文本。imagefilename对应于CAPTCHA图像的文件名,text包含CAPTCHA中描述的字母数字文本...
在这个“SSM实现登录验证码功能”的项目中,我们将探讨如何在SSM框架下添加验证码功能,以增强用户登录的安全性。 首先,验证码功能的基本目的是防止恶意自动化程序(如机器人或爬虫)进行非法操作,如频繁尝试登录...