---------------------------------------------------------------------------------------------------------------
[版权申明:本文系作者原创,转载请注明出处]
文章出处:http://blog.csdn.net/sdksdk0/article/details/51755489
作者:朱培   ID:sdksdk0
---------------------------------------------------------------------------------------------------------------

今天分享的是通过ajax来动态的验证验证码输入是否正确。我们这里采用的是ajax+struts2来做的这个验证。 我们新建一个web工程。然后需要导入struts的相应包。之后我们需要写一个类来生成验证码。

这里命名为01_image.jsp,这类的主要功能就是生成验证码,里面是各种画线条,随机数字等,我这里设置的是5个数字的验证,如果你想要改成其他的也可以,大致思路就是在生成数字的那个循环那里加上字母就可以了。

  1. <%@ page language="java" pageEncoding="UTF-8"%>
  2. <%@ page contentType="image/jpeg" import="java.awt.*,java.awt.image.*,java.util.*,javax.imageio.*" %>
  3. <%!
  4. public Color getColor(){
  5. Random random = new Random();
  6. int r = random.nextInt(256);//0-255
  7. int g = random.nextInt(256);
  8. int b = random.nextInt(256);
  9. return new Color(r,g,b);
  10. }
  11. public String getNum(){
  12. String str = "";
  13. Random random = new Random();
  14. for(int i=0;i<5;i++){
  15. str += random.nextInt(10);//0-9
  16. }
  17. return str;
  18. }
  19. %>
  20. <%
  21. response.setHeader("pragma", "no-cache");
  22. response.setHeader("cache-control", "no-cache");
  23. response.setDateHeader("expires", 0);
  24. BufferedImage image = new BufferedImage(80,30,BufferedImage.TYPE_INT_RGB);
  25. Graphics g = image.getGraphics();
  26. g.setColor(new Color(200,200,200));
  27. g.fillRect(0,0,80,30);
  28. for (int i = 0; i < 50; i++) {
  29. Random random = new Random();
  30. int x = random.nextInt(80);
  31. int y = random.nextInt(30);
  32. int xl = random.nextInt(x+10);
  33. int yl = random.nextInt(y+10);
  34. g.setColor(getColor());
  35. g.drawLine(x, y, x + xl, y + yl);
  36. }
  37. g.setFont(new Font("serif", Font.BOLD,16));
  38. g.setColor(Color.BLACK);
  39. String checkNum = getNum();//"2525"
  40. StringBuffer sb = new StringBuffer();
  41. for(int i=0;i<checkNum.length();i++){
  42. sb.append(checkNum.charAt(i)+" ");//"2 5 2 5"
  43. }
  44. g.drawString(sb.toString(),15,20);
  45. session.setAttribute("CHECKNUM",checkNum);//2525
  46. //通过字节输出流输出
  47. ImageIO.write(image,"jpeg",response.getOutputStream());
  48. out.clear();
  49. out = pageContext.pushBody();
  50. %>

接下来把输入验证码的html页面写好,我这里是些在了一个jsp文件中的。命名为checkcode.jsp

  1. <th>验证码:</th>
  2. <td><input type="text" name="checkcode" id="checkcodeID" maxlength="5" /></td>
  3. <td><img src="01_image.jsp" id="imgID" /></td>
  4. <td id="resID"></td>
  5. </tr>
  6. </table>
  7. </form>

然后给这个文件添加javascript代码,这里使用的当然就是一个ajax啦,对于ajax的编码步骤之前已经写的很详细了,所以我们这里就直接使用了。 对于ajax.js写好后放到js目录下面,然后再找个checkcode.jsp中引入中国js文件 ajax.js的内容:

  1. //创建AJAX异步对象,即XMLHttpRequest
  2. function createAJAX(){
  3. var ajax = null;
  4. try{
  5. ajax = new ActiveXObject("microsoft.xmlhttp");
  6. }catch(e1){
  7. try{
  8. ajax = new XMLHttpRequest();
  9. }catch(e2){
  10. alert("你的浏览器不支持ajax,请更换浏览器");
  11. }
  12. }
  13. return ajax;
  14. }

然后就是chenkcode中的js内容了

  1. //去掉两边的空格
  2. function trim(str){
  3. str=str.replace(/^\s*/,"");//从左侧开始,把空格去掉
  4. str=str.replace(/\s*$/,""); //从右侧开始,把K歌都去掉
  5. return str;
  6. }
  7. document.getElementById("checkcodeID").onkeyup=function(){
  8. var checkcode=this.value;
  9. checkcode=trim(checkcode);
  10. if(checkcode.length==5){
  11. var ajax=createAJAX();
  12. var method="POST";
  13. var url = "${pageContext.request.contextPath}/checkRequest?time="+new Date().getTime();
  14. ajax.open(method,url);
  15. //设置ajax请求头为post,它会将请求的汉字自动进行utf-8的编码
  16. ajax.setRequestHeader("content-type","application/x-www-form-urlencoded");
  17. var content="checkcode="+checkcode;
  18. ajax.send(content);
  19. ajax.onreadystatechange=function(){
  20. if(ajax.readyState==4){
  21. if(ajax.status==200){
  22. var tip=ajax.responseText;
  23. var img=document.createElement("img");
  24. img.src=tip;
  25. img.style.width="14px";
  26. img.style.height="14px";
  27. var td=document.getElementById("resID");
  28. td.innerHTML="";
  29. td.appendChild(img);
  30. }
  31. }
  32. }
  33. }else{
  34. var td=document.getElementById("resID");
  35. td.innerHTML="";
  36. }
  37. }

然后开始写服务器端的代码,进行校验的话就需要这样的一个类了:

  1. package cn.tf.checkcode;
  2. import java.io.IOException;
  3. import java.io.PrintWriter;
  4. import javax.servlet.http.HttpServletResponse;
  5. import org.apache.struts2.ServletActionContext;
  6. import com.opensymphony.xwork2.ActionContext;
  7. import com.opensymphony.xwork2.ActionSupport;
  8. //验证码检查
  9. public class CheckcodeAction extends ActionSupport{
  10. private String checkcode;
  11. public void setCheckcode(String checkcode) {
  12. this.checkcode = checkcode;
  13. }
  14. /**
  15. * 验证
  16. * @throws IOException
  17. */
  18. public String check() throws IOException {
  19. //图片路径
  20. String tip="images/a.jpg";
  21. //从服务器获取session中的验证码
  22. String checkcodeServer=(String) ActionContext.getContext().getSession().get("CHECKNUM");
  23. if(checkcode.equals(checkcodeServer)){
  24. tip="images/b.jpg";
  25. }
  26. //以IO流的方式将tip变量输出到ajax异步对象中
  27. HttpServletResponse response=ServletActionContext.getResponse();
  28. response.setContentType("text/html;charset=UTF-8");
  29. PrintWriter pw=response.getWriter();
  30. pw.write(tip);
  31. pw.flush();
  32. pw.close();
  33. return null;
  34. }
  35. }

最后在struts.xml文件中写入相应的方法。

  1. <struts>
  2. <package name="myPackage" extends="struts-default" namespace="/">
  3. <action
  4. name="checkRequest"
  5. class="cn.tf.checkcode.CheckcodeAction"
  6. method="check">
  7. </action>
  8. </package>
  9. </struts>

运行结果如下:验证成功则返回绿色的小勾,错误则红色的叉。

源码下载地址:http://download.csdn.net/detail/sdksdk0/9558933

Ajax+Struts2实现验证码验证功能的更多相关文章

  1. PHP实现邮箱验证码验证功能

    *文章来源:https://blog.egsec.cn/archives/623  (我的主站) *本文将主要说明:PHP实现邮箱验证码验证功能,通过注册或登录向用户发送身份确认验证码,并通过判断输入 ...

  2. PHP网站提交表单如何实现验证码验证功能

    很多小伙伴在原生网站时候都会遇到很多意料之外的情况发生,也有不少小伙伴在初学程序代码的时候可能会因为一个小小的逗号隐藏在几百行,几千行的代码中出错常见的在提交表单中很多事需要验证码验证,那么如何来实现 ...

  3. JavaWeb学习记录(六)——用户登录功能之Session与验证码验证功能的实现

    一.产生验证码的工具类 package blank.util; import java.awt.Color;import java.awt.Graphics;import java.awt.image ...

  4. [phpcms v9]自定义表单添加验证码验证功能

    修改  \phpcms\templates\default\formguide\show.html 中添加验证码显示 <input type="text" id=" ...

  5. 实例:SSH结合Easyui实现Datagrid的新增功能和Validatebox的验证功能

    在我前面一篇分页的基础上,新增了添加功能和添加过程中的Ajax与Validate的验证功能.其他的功能在后面的博客写来,如果对您有帮助,敬请关注. 先看一下实现的效果: (1)点击添加学生信息按键后跳 ...

  6. Java进阶知识01 Struts2下的 jquery+ajax+struts 技术实现异步刷新功能

    1.效果图示 横线上方的部分不动(没有刷新),下方实现刷新(异步刷新) 2.实现步骤 jquery+ajax+struts技术实现异步刷新功能的步骤:    1.需要用到 jquery+ajax+st ...

  7. JQuery+Ajax+Struts2+Hibernate 实现完整的登录注册

    写在最前: 下午有招聘会,不想去,总觉得没有准备好,而且都是一些不对口的公司,可是又静不下心来,就来写个博客. 最近在仿造一个书城的网站:http://www.yousuu.com ,UI直接拿来用, ...

  8. Spring Security4实例(Java config版)——ajax登录,自定义验证

    本文源码请看这里 相关文章: Spring Security4实例(Java config 版) -- Remember-Me 首先添加起步依赖(如果不是springboot项目,自行切换为Sprin ...

  9. 如何实现php手机短信验证功能

    http://www.qdexun.cn/jsp/news/shownews.do?method=GetqtnewsdetailAction&id=1677 下载php源代码 现在网站在建设网 ...

随机推荐

  1. Ubuntu 18.04 LTS修改 国内源(以中科大源为例)

    国内有很多Ubuntu的镜像源,包括阿里的.网易的,还有很多教育网的源,比如:清华源.中科大源. 我们这里以中科大的源为例讲解如何修改Ubuntu 18.04里面默认的源. 可以进入这个链接进行下载: ...

  2. 使用Navicat Premium 链接本地数据库的方法(二)

    最早一篇:http://www.cnblogs.com/zhengyeye/p/6363179.html 现在又重新装了电脑系统,需遇到了同样的问题.恰巧记得之前自己写的文档,没准可以帮助自己解决掉这 ...

  3. 洛谷 P3038 [USACO11DEC]牧草种植Grass Planting(树链剖分)

    题解:仍然是无脑树剖,要注意一下边权,然而这种没有初始边权的题目其实和点权也没什么区别了 代码如下: #include<cstdio> #include<vector> #in ...

  4. 学习HTML的第一次课

    1.母板中的标签的含义 1.1< Doctype html/ > 声明文档类型为HTML 1.2< meta charset="UTF-8"/ > 设当前网 ...

  5. 创建类似于Oracle中decode的函数

    -- 创建类似于Oracle中decode的函数create or replace function decode(variadic p_decode_list text[])returns text ...

  6. 深入解析浏览器的幕后工作原理(三) 呈现树和 DOM 树的关系

    呈现树和 DOM 树的关系 呈现器是和 DOM 元素相对应的,但并非一一对应.非可视化的 DOM 元素不会插入呈现树中,例如"head"元素.如果元素的 display 属性值为& ...

  7. [ABP]浅谈模块系统与 ABP 框架初始化

    在 ABP 框架当中所有库以及项目都是以模块的形式存在,所有模块都是继承自AbpModule 这个抽象基类,每个模块都拥有四个生命周期.分别是: PreInitialze(); Initialize( ...

  8. [LeetCode] Circular Array Loop 环形数组循环

    You are given an array of positive and negative integers. If a number n at an index is positive, the ...

  9. ●BZOJ 2006 NOI 2010 超级钢琴

    题链: http://www.lydsy.com/JudgeOnline/problem.php?id=2006 题解: RMQ + 优先队列 (+ 前缀) 记得在一两个月前,一次考试考了这个题目的简 ...

  10. HDU 1729

    给定一个m × n (m行, n列)的迷宫,迷宫中有两个位置,gloria想从迷宫的一个位置走到另外一个位置 她在行走过程中,不能转太多弯了,否则她会晕倒的. (每次在一个方向上一直走到底,并push ...