jcaptcha 之 图片验证码

本文介绍如何利用jCaptcha结合Ajax技术实现网页验证码的无刷新更新功能。文章详细展示了通过iframe加载验证码图片,并使用JavaScript进行验证码刷新的方法。此外,还提供了基于Servlet的验证码生成与验证的具体实现。
通过iframe 实现的"Ajax" 实现刷新验证码 你懂得 ,项目还要添加jcaptcha包
我这边是添加的 jcaptcha源码 ,喜欢看源码的JE朋友可以通过svn
https://jcaptcha.svn.sourceforge.net/svnroot/jcaptcha

还需要添加


主要提供页面
Index.jsp

<html>
<head>
<title>jcaptcha example</title>
</head>
<script type="text/javascript" src="<%=path%>/js/jquery/jquery.js"></script>
<script type="text/javascript">
function ajaxRefresh(){

//兼容 IE Firefox Safari
document.getElementById('image').contentWindow.location.reload();
//$("#image").get(0).src="ImageCaptchaServlet.servlet";
}

function ajaxValidateCapt(){
var captchaId ;
captchaId = jQuery('#captchaId').val();
jQuery.ajax({
type: "POST",
url: "ValidateCaptcha.servlet",
data: {"captchaId":captchaId},
success: function(msg){
jQuery('#_msg').html(msg);
}
});
}

</script>
<body>
<div id="_msg"></div>
请填写验证码:<br/>
<iframe width="120" height="70" id="image" src="image.jsp" frameborder="0"></iframe><br>
<a href="javascript:void(0)" onclick="ajaxRefresh()">ajaxRefresh</a>
<br>
<input type='text' name='captchaId' id='captchaId' value=''><br>
<input type="button" onclick="ajaxValidateCapt()" value="提交">
</body>
</html>


image.jsp

<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=ISO-8859-1">
<title>Insert title here</title>
</head>
<body>
<img width="85" height="41" src="ImageCaptchaServlet.servlet" onclick="ajaxRefresh()" ><br/>
</body>
</html>

web.xml 以下是配置的Servlet

<web-app xmlns:javaee="http://java.sun.com/xml/ns/javaee" xmlns:web="http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd">
<!-- 验证码生成 -->
<servlet>
<javaee:description></javaee:description>
<javaee:display-name>ImageCaptchaServlet</javaee:display-name>
<servlet-name>ImageCaptchaServlet</servlet-name>
<servlet-class>captcha.servlet.ImageCaptchaServlet</servlet-class>
</servlet>
<servlet-mapping>
<servlet-name>ImageCaptchaServlet</servlet-name>
<url-pattern>/ImageCaptchaServlet.servlet</url-pattern>
</servlet-mapping>

<!-- 验证 验证码 -->
<servlet>
<javaee:description></javaee:description>
<javaee:display-name>ValidateCaptcha</javaee:display-name>
<servlet-name>ValidateCaptcha</servlet-name>
<servlet-class>captcha.servlet.ValidateCaptchaServlet</servlet-class>
</servlet>
<servlet-mapping>
<servlet-name>ValidateCaptcha</servlet-name>
<url-pattern>/ValidateCaptcha.servlet</url-pattern>
</servlet-mapping>
</web-app>


CaptchaServiceSingleton.java
获取ImageCaptchaService 对象

package captcha;

import com.octo.captcha.service.image.DefaultManageableImageCaptchaService;
import com.octo.captcha.service.image.ImageCaptchaService;

/**
* 获取ImageCaptchaService 对象
* 如果是SPRING 可以通过注入进行获取对象
* @author Administrator
*
*/
public class CaptchaServiceSingleton {

private static ImageCaptchaService instance = null;

private CaptchaServiceSingleton(){

}
//单利实现
public static ImageCaptchaService getInstance() {
if(null!=instance){
return instance;
}
return instance = new DefaultManageableImageCaptchaService();
}
}


ImageCaptchaServlet.java
验证码生成

package captcha.servlet;

import java.awt.image.BufferedImage;
import java.io.ByteArrayOutputStream;
import java.io.IOException;

import javax.servlet.ServletConfig;
import javax.servlet.ServletException;
import javax.servlet.ServletOutputStream;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

import captcha.CaptchaServiceSingleton;

import com.octo.captcha.service.CaptchaServiceException;
import com.sun.image.codec.jpeg.JPEGCodec;
import com.sun.image.codec.jpeg.JPEGImageEncoder;


public class ImageCaptchaServlet extends HttpServlet {


/**
* simple-servlet-image-sample
* @Title: ImageCaptchaServlet.java
* @Package captcha.servlet
* @Description: TODO
* @author liazhou
* @date 2012-1-6 下午03:03:54
* @version V1.0
*/
private static final long serialVersionUID = -4590982813167593710L;


public void init(ServletConfig servletConfig) throws ServletException {

super.init(servletConfig);

}


protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
// TODO Auto-generated method stub
this.doPost(request, response);
}

protected void doPost(HttpServletRequest httpServletRequest, HttpServletResponse httpServletResponse) throws ServletException, IOException {

byte[] captchaChallengeAsJpeg = null;
ByteArrayOutputStream jpegOutputStream = new ByteArrayOutputStream();
try {
//相关联的 HttpSession 得到会话id来识别,产生相应的验证码
String captchaId = httpServletRequest.getSession().getId();
// Method to retrive the image challenge corresponding to the given ticket.
BufferedImage challenge = CaptchaServiceSingleton.getInstance().getImageChallengeForID(captchaId,
httpServletRequest.getLocale());
JPEGImageEncoder jpegEncoder = JPEGCodec.createJPEGEncoder(jpegOutputStream);
jpegEncoder.encode(challenge);
} catch (IllegalArgumentException e) {
httpServletResponse.sendError(HttpServletResponse.SC_NOT_FOUND);
return;
} catch (CaptchaServiceException e) {
httpServletResponse.sendError(HttpServletResponse.SC_INTERNAL_SERVER_ERROR);
return;
}
captchaChallengeAsJpeg = jpegOutputStream.toByteArray();
httpServletResponse.setHeader("Cache-Control", "no-store");
httpServletResponse.setHeader("Pragma", "no-cache");
httpServletResponse.setDateHeader("Expires", 0);
httpServletResponse.setContentType("image/jpeg");
ServletOutputStream responseOutputStream =
httpServletResponse.getOutputStream();
responseOutputStream.write(captchaChallengeAsJpeg);
responseOutputStream.flush();
responseOutputStream.close();
}
}


ValidateCaptchaServlet.java
验证码的验证

package captcha.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 captcha.CaptchaServiceSingleton;

/**
* Servlet implementation class ValidateCaptcha
*/
public class ValidateCaptchaServlet extends HttpServlet {
private static final long serialVersionUID = 1L;

/**
* @see HttpServlet#HttpServlet()
*/
public ValidateCaptchaServlet() {
super();
// TODO Auto-generated constructor stub
}

/**
* @see HttpServlet#doGet(HttpServletRequest request, HttpServletResponse response)
*/
protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
// TODO Auto-generated method stub
this.doPost(request, response);
}

/**
* @see HttpServlet#doPost(HttpServletRequest request, HttpServletResponse response)
*/
protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
// TODO Auto-generated method stub
boolean bool = false;
String message = "";
String captchaId = request.getParameter("captchaId");
if(null!=captchaId && !"".equals(captchaId)){
//通过session id 获取 对应的验证码对象并验证是否正确
bool = CaptchaServiceSingleton.getInstance().validateResponseForID(request.getSession().getId(), captchaId);
}
if(bool){
message = "验证成功";
}else{
message= "验证失败";
}
response.setCharacterEncoding("UTF-8");
response.getWriter().print(message);
// request.getRequestDispatcher("").forward(request, response);
}

}




页面及依赖jar截图

[img]http://dl.iteye.com/upload/attachment/0061/7645/d6aba5ce-f6fd-354e-9d0a-14ba328155d0.png[/img]

[img]http://dl.iteye.com/upload/attachment/0061/7641/8d432304-b9ed-3cfb-8e1d-0785d1296a16.png[/img]
标题基于Python的自主学习系统后端设计与实现AI更换标题第1章引言介绍自主学习系统的研究背景、意义、现状以及本文的研究方法和创新点。1.1研究背景与意义阐述自主学习系统在教育技术领域的重要性和应用价值。1.2国内外研究现状分析国内外在自主学习系统后端技术方面的研究进展。1.3研究方法与创新点概述本文采用Python技术栈的设计方法和系统创新点。第2章相关理论与技术总结自主学习系统后端开发的相关理论和技术基础。2.1自主学习系统理论阐述自主学习系统的定义、特征和理论基础。2.2Python后端技术栈介绍DjangoFlask等Python后端框架及其适用场景。2.3数据库技术讨论关系型和非关系型数据库在系统中的应用方案。第3章系统设计与实现详细介绍自主学习系统后端的设计方案和实现过程。3.1系统架构设计提出基于微服务的系统架构设计方案。3.2核心模块设计详细说明用户管理、学习资源管理、进度跟踪等核心模块设计。3.3关键技术实现阐述个性化推荐算法、学习行为分析等关键技术的实现。第4章系统测试与评估对系统进行功能测试和性能评估。4.1测试环境与方法介绍测试环境配置和采用的测试方法。4.2功能测试结果展示各功能模块的测试结果和问题修复情况。4.3性能评估分析分析系统在高并发等场景下的性能表现。第5章结论与展望总结研究成果并提出未来改进方向。5.1研究结论概括系统设计的主要成果和技术创新。5.2未来展望指出系统局限性并提出后续优化方向。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值