`

验证码使用总结

    博客分类:
  • Java
阅读更多
Servlet生成验证码
public class CaptchaServlet extends HttpServlet {
    private static final long serialVersionUID = -5051097528828603895L;
    private int width = 100;
    private int height = 30;
    private int codeCount = 4;
    private int fontHeight;
    private int codeX;
    private int codeY;

    char[] codeSequence = {'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'};

    public void init() throws ServletException {

        String strWidth = this.getInitParameter("width");
        String strHeight = this.getInitParameter("height");
        String strCodeCount = this.getInitParameter("codeCount");

        try {
            if (strWidth != null && strWidth.length() != 0) {
                width = Integer.parseInt(strWidth);
            }
            if (strHeight != null && strHeight.length() != 0) {
                height = Integer.parseInt(strHeight);
            }
            if (strCodeCount != null && strCodeCount.length() != 0) {
                codeCount = Integer.parseInt(strCodeCount);
            }
        } catch (NumberFormatException e) {
            e.printStackTrace();
        }
        codeX = (width - 4) / (codeCount + 1);
        fontHeight = height - 10;
        codeY = height - 7;
    }

    protected void service(HttpServletRequest request, HttpServletResponse response) throws ServletException, java.io.IOException {
        BufferedImage buffImg = new BufferedImage(width, height, BufferedImage.TYPE_INT_RGB);
        Graphics2D gd = buffImg.createGraphics();
        Random random = new Random();
        gd.setColor(Color.LIGHT_GRAY);
        gd.fillRect(0, 0, width, height);
        Font font = new Font("Fixedsys", Font.PLAIN, fontHeight);
        gd.setFont(font);
        gd.setColor(Color.BLACK);
        gd.drawRect(0, 0, width - 1, height - 1);
        gd.setColor(Color.gray);
        for (int i = 0; i < 16; i++) {
            int x = random.nextInt(width);
            int y = random.nextInt(height);
            int xl = random.nextInt(12);
            int yl = random.nextInt(12);
            gd.drawLine(x, y, x + xl, y + yl);
        }
        StringBuffer randomCode = new StringBuffer();
        int red = 0;
        int green = 0;
        int blue = 0;
        for (int i = 0; i < codeCount; i++) {
            String strRand = String.valueOf(codeSequence[random.nextInt(36)]);
            red = random.nextInt(255);
            green = random.nextInt(255);
            blue = random.nextInt(255);
            gd.setColor(new Color(red, green, blue));
            gd.drawString(strRand, (i + 1) * codeX, codeY);
            randomCode.append(strRand);
        }
        HttpSession session = request.getSession();
        session.setAttribute("captcha", randomCode.toString());
        response.setHeader("Pragma", "no-cache");
        response.setHeader("Cache-Control", "no-cache");
        response.setDateHeader("Expires", 0);
        response.setContentType("image/jpeg");
        ServletOutputStream sos = response.getOutputStream();
        ImageIO.write(buffImg, "jpeg", sos);
        sos.close();
    }
}


Web.xml中的配置
<servlet>
        <servlet-name>CaptchaServlet</servlet-name>
        <servlet-class>com.quidsi.emm.track.util.CaptchaServlet</servlet-class>
        <init-param>
            <param-name>width</param-name>
            <param-value>120</param-value>
        </init-param>
        <init-param>
            <param-name>height</param-name>
            <param-value>32</param-value>
        </init-param>
        <init-param>
            <param-name>codeCount</param-name>
            <param-value>4</param-value>
        </init-param>
    </servlet>
    <servlet-mapping>
        <servlet-name>CaptchaServlet</servlet-name>
        <url-pattern>/CaptchaServlet</url-pattern>
    </servlet-mapping>


页面中的使用:
 <div>
	Captcha:<input id="inputCode" name="inputCode" />
	<img src="CaptchaServlet" align="middle" title="Look not clear, please click me"  onclick="javascript:refresh(this);" onmouseover="mouseover(this)"/>
</div>


相关问题
1、浏览器后退,可以不断重复提交。js禁用后退:<script language="JavaScript">javascript:window.history.forward(1);</script>
2、前端页面验证码输入验证时,从后台取到的验证码与页面显示的验证码慢一拍。
   解决方案:(1)、在提交的时候通过ajax请求取得最新的验证码。
             (2)、直接后台验证一次,验证失败回写前台
3、跨域请求,改用相对路径
4、javax.imageio.IIOException: Can't create output stream!
   原因:ImageIO依赖于Tomcat的temp目录,如temp目录遗失就会报上述错误
   解决方案:(1)、(不推荐)在tomcat目录下加上temp目录
             (2)、(不推荐)把ImageIO.write(image, "jpeg", response.getOutputStream());修改为
JPEGImageEncoder encoder = JPEGCodec.createJPEGEncoder(response.getOutputStream());
encoder.encode(image);
(3)、禁用缓存ImageIO.setUseCache(false);
分享到:
评论

相关推荐

    验证码安全总结.xmind

    验证码安全总结

    C#多种验证码方法总结

    本文将对"C#"编程语言中实现验证码的各种方法进行详细总结。 1. 图形验证码(Image CAPTCHA) - 图形验证码是最常见的类型,通过生成随机的字符或数字组合,然后扭曲、旋转、加噪,形成一张图片。在C#中,我们可以...

    vue插件——使用canvas生成图形验证码

    总结一下,这个“vue插件——使用canvas生成图形验证码”结合了Vue.js的组件化和canvas的图形绘制能力,为Web应用提供了一种安全、可定制的图形验证码解决方案。它既保证了用户验证的安全性,又利用Vue.js的便利性...

    实验五 AJAX开发及JSP验证码

    这个实验旨在让学生熟悉AJAX的基本使用以及如何结合JSP生成和验证验证码,提高Web应用的交互性和安全性。通过这样的练习,开发者可以更好地理解和应用前端异步通信以及服务器端的动态交互技术。

    谷歌验证码使用工具——kaptcha-2.3.2

    总结来说,kaptcha-2.3.2是Java开发中一个强大且灵活的验证码解决方案,它的出现使得开发者能够轻松地在项目中集成高质量的验证码功能,为网站的安全性提供了有力保障。通过理解和掌握kaptcha的使用,开发者可以更好...

    使用Servlet生成图片验证码

    总结起来,"使用Servlet生成图片验证码"涉及到以下几个关键知识点: 1. Servlet生命周期和HTTP请求响应机制。 2. Java图形绘制,主要利用Graphics2D类创建验证码图片。 3. 部署描述符`web.xml`的配置,包括Servlet的...

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

    描述中的“js验证码插件”指的是使用JavaScript编写的轻量级验证码解决方案,它通常包含几个关键组件: - **生成器**:生成随机字符串并转化为图像。 - **渲染器**:在HTML页面上展示验证码图像。 - **验证器**...

    ASP.NET中如何使用验证码效验

    总结来说,ASP.NET中的验证码机制是通过HTTP Handler生成随机字符串并以图像形式显示,然后在用户输入后进行匹配验证,确保了登录的安全性。理解和掌握这一机制对于任何ASP.NET开发者来说都是至关重要的,因为它可以...

    验证码控件 C#验证码控件

    总结来说,C#验证码控件是C#开发中不可或缺的安全组件,它能够帮助开发者构建更安全的用户验证机制,防止自动化攻击。通过理解并熟练掌握其特性和用法,开发者可以更好地保护自己的应用程序免受恶意活动的影响。

    生成验证码(带详细注释、Servlet已获取生成的验证码和输入的验证码)

    总结,本项目实现了基于Java Servlet的验证码生成与验证功能,涵盖了随机数生成、图像处理、HTTP交互等多个技术点。通过对验证码的生成、发送、验证以及前端的交互处理,确保了用户输入的安全性和系统的可靠性。

    beego框架图形验证码实现

    总结起来,beego框架的图形验证码实现是通过Go语言的强大功能和灵活性实现的,它提供了高度定制化的选项,使得验证码更难被自动化程序破解,从而保护了Web应用的安全。通过深入理解和实践`gocaptcha-master`,开发者...

    html5点击刷新验证码特效

    总结来说,“html5点击刷新验证码特效”是HTML5技术在网页安全领域的一种应用,它结合了Canvas、JavaScript和CSS,实现了验证码的动态刷新功能,提高了网站的安全性和用户体验。在实际开发中,我们还需要考虑到性能...

    测试中去掉登录验证码

    总结来说,测试中去掉登录验证码主要是通过模拟、代码修改、配置调整等方式来实现,目的是简化测试流程,提高测试效率。然而,这种方法仅适用于测试环境,并且在测试结束后必须恢复验证码功能,以保障系统的正常运行...

    4位含字母和数字随机验证码

    3. **不可重复性**:一旦验证码被使用,无论是正确输入还是错误尝试,都应立即失效,以防止同一验证码被多次使用。 4. **时效性**:验证码通常有有效期,过期后会自动失效,这样可以降低因验证码泄露而产生的风险。...

    .net使用一般处理程序生成验证码

    总结起来,使用.NET的一般处理程序生成验证码涉及了HTTP请求处理、图形绘制、随机数生成以及HTTP响应配置等多个方面。通过这种方式,我们可以创建一个自定义的、安全的验证码服务,为Web应用程序提供额外的安全保障...

    自动化测试中的验证码处理方法小总结.docx

    目前,不少网站在用户登录、用户提交信息等登录和输入的页面上使用了验证码技术。验证码技术可以有效防止恶意用户对网站的滥用,使得网站可以有效避免用户信息失窃、广告SPAM等问题。但与此同时,验证码技术的使用却...

    验证码的生成,如何随机生成验证码

    总结来说,创建一个区分大小写的ASP.NET验证码涉及随机字符串生成、图形化表示以及服务器端和客户端的交互。理解和实现这个过程对于提升网站安全性至关重要。同时,验证码识别技术的发展也展示了网络安全领域的持续...

    C#验证码 验证码绘制在图片上

    标题与描述概述的知识点主要集中在使用C#编程语言来生成并绘制验证码到图片上。这一技术在现代网站和应用程序的安全性方面扮演着重要的角色,它能够有效地防止自动化工具的恶意登录尝试,保护用户数据安全。 ### ...

    java随机产生验证码

    总结来说,Java生成随机验证码的过程主要包括以下步骤: 1. 定义图像尺寸和类型。 2. 生成随机颜色作为背景色。 3. 设置字体样式和颜色。 4. 随机生成验证码内容,并将其绘制到图像上。 5. 将图像保存为指定格式的...

    Asp.net 验证码控件

    总结来说,Asp.net验证码控件是防止自动化攻击的重要工具。正确地选择和使用验证码控件,可以帮助提高网站的安全性,同时平衡用户体验。了解其工作原理、类型和使用方法,对于Asp.net开发者来说至关重要。

Global site tag (gtag.js) - Google Analytics