jsp+ajax实现的局部刷新较验验证码(onblur事件触发较验)
本文实例讲述了jsp+ajax实现的局部刷新较验验证码(onblur事件触发较验)。分享给大家供大家参考,具体如下:
前台显示页面:
welcome.jsp
<%@pagelanguage="java"contentType="text/html;utf-8" pageEncoding="utf-8"%> <!DOCTYPEhtmlPUBLIC"-//W3C//DTDHTML4.01Transitional//EN""http://www.w3.org/TR/html4/loose.dtd"> <html> <head> <metahttp-equiv="Content-Type"content="text/html;charset=utf-8"> <title>修改个人信息</title> <script> functioncreateXMLHttpRequest(){ //表示当前浏览器不是ie,如ns,firefox if(window.XMLHttpRequest){ xmlHttp=newXMLHttpRequest(); }elseif(window.ActiveXObject){ xmlHttp=newActiveXObject("Microsoft.XMLHTTP"); } } functionvalidate(field){ vardiv=document.getElementById("divbid"); //varreg=/[^A-Za-z0-9_]{7,10}/g; if(field.value.length!=0){ //创建XMLHttpRequest createXMLHttpRequest(); varurl="codevalidate.jsp?authcode="+field.value+"×tamp="+newDate().getTime();//加时间戳防止缓存重复 xmlHttp.open("GET",url,true); //方法地址,处理完成后自动调用,回调 xmlHttp.onreadystatechange=function(){//匿名函数 if(xmlHttp.readyState==4){//Ajax引擎初始化成功 if(xmlHttp.status==200){//http协议成功 document.getElementById("divbid").innerHTML=xmlHttp.responseText; }else{ alert("请求失败,错误码="+xmlHttp.status); } } }; //将参数发送到Ajax引擎 xmlHttp.send(null); }else{ div.innerHTML="<divclass=\"wrong\">验证码不能为空</div>" } } functionreloadImage(imgurl){ vargetimagecode=document.getElementById("codeimg"); getimagecode.src=imgurl+"?id="+Math.random(); varcode=<%=session.getAttribute("code")%>; alert(code) } </script> </head> <body> <formaction="authcode.jsp"method="post"name="loginform"> 输入验证码:<inputtype="text"name="authcode"id="authcode"maxlength="4"size="10"onblur="validate(this)"><spanid="divbid"></span> <imgid="codeimg"name="codeimg"border=0src="authcode.jsp"> <ahref="javascript:reloadImage('authcode.jsp')">看不清</a><br/> </form> <scriptlanguage="javascript"type="text/javascript"> functionreloadImage(imgurl){ vargetimagecode=document.getElementById("codeimg"); getimagecode.src=imgurl+"?id="+Math.random(); varcode=<%=session.getAttribute("code")%>; alert(code) } </script> </body> </html>
产生图片页面
authcode.jsp
<%@pagecontentType="image/JPEG" import="java.awt.*,java.awt.image.*,java.util.*,javax.imageio.*" pageEncoding="GBK"%> <%!ColorgetRandColor(intfc,intbc){//给定范围获得随机颜色 Randomrandom=newRandom(); if(fc>255) fc=255; if(bc>255) bc=255; intr=fc+random.nextInt(bc-fc); intg=fc+random.nextInt(bc-fc); intb=fc+random.nextInt(bc-fc); returnnewColor(r,g,b); }%> <% //设置页面不缓存 response.setHeader("Pragma","No-cache"); response.setHeader("Cache-Control","no-cache"); response.setDateHeader("Expires",0); //在内存中创建图象 intwidth=60,height=20; BufferedImageimage=newBufferedImage(width,height, BufferedImage.TYPE_INT_RGB); //获取图形上下文 Graphicsg=image.getGraphics(); //生成随机类 Randomrandom=newRandom(); //设定背景色 g.setColor(getRandColor(200,250)); g.fillRect(0,0,width,height); //设定字体 g.setFont(newFont("TimesNewRoman",Font.PLAIN,18)); //画边框 //g.setColor(newColor()); //g.drawRect(0,0,width-1,height-1); //随机产生155条干扰线,使图象中的认证码不易被其它程序探测到 g.setColor(getRandColor(160,200)); for(inti=0;i<100;i++){ intx=random.nextInt(width); inty=random.nextInt(height); intxl=random.nextInt(12); intyl=random.nextInt(12); g.drawLine(x,y,x+xl,y+yl); } //取随机产生的认证码(4位数字) StringsRand=""; for(inti=0;i<4;i++){ Stringrand=String.valueOf(random.nextInt(10)); sRand+=rand; //将认证码显示到图象中 g.setColor(newColor(20+random.nextInt(110),20+random .nextInt(110),20+random.nextInt(110)));//调用函数出来的颜色相同,可能是因为种子太接近,所以只能直接生成 g.drawString(rand,13*i+6,16); System.out.println(rand); } //将认证码存入SESSION session.setAttribute("code",sRand); //图象生效 g.dispose(); //输出图象到页面 ImageIO.write(image,"JPEG",response.getOutputStream()); %>
ajax动态验证页面
codevalidate.jsp
<%@pagelanguage="java"import="java.util.*,java.util.*,java.text.*,com.neusoft.xkxt.dao.*,com.neusoft.xkxt.bean.*,com.neusoft.xkxt.util.*"pageEncoding="UTF-8"%> <% Stringpath=request.getContextPath(); StringbasePath=request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/"; %> <% Stringauthcode=request.getParameter("authcode"); Stringcode=(String)session.getAttribute("code"); if(authcode.equals(code)){ out.println("<divclass='right'>√</div>");} else{ out.println("<divclass='wrong'>验证码不正确</div>");} %>
希望本文所述对大家JSP程序设计有所帮助。