java验证码局部刷新_jsp+ajax实现的局部刷新较验验证码(onblur事件触发较验)

本文实例讲述了jsp+ajax实现的局部刷新较验验证码(onblur事件触发较验)。分享给大家供大家参考,具体如下:

welcome.jsp

pageEncoding="utf-8"%>

修改个人信息

function createXMLHttpRequest() {

//表示当前浏览器不是ie,如ns,firefox

if(window.XMLHttpRequest) {

xmlHttp = new XMLHttpRequest();

} else if (window.ActiveXObject) {

xmlHttp = new ActiveXObject("Microsoft.XMLHTTP");

}

}

function validate(field) {

var div=document.getElementById("divbid");

// var reg=/[^A-Za-z0-9_]{7,10}/g;

if (field.value.length != 0) {

//创建XMLHttpRequest

createXMLHttpRequest();

var url = "codevalidate.jsp?authcode=" + field.value + "×tamp=" + new Date().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="

验证码不能为空
"

}

}

function reloadImage(imgurl){

var getimagecode=document.getElementById("codeimg");

getimagecode.src= imgurl + "?id=" + Math.random();

var code=;

alert(code)

}

输入验证码:

authcode.jsp

看不清

function reloadImage(imgurl){

var getimagecode=document.getElementById("codeimg");

getimagecode.src= imgurl + "?id=" + Math.random();

var code=;

alert(code)

}

authcode.jsp

import="java.awt.*,java.awt.image.*,java.util.*,javax.imageio.*"

pageEncoding="GBK"%>

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);

}%>

//设置页面不缓存

response.setHeader("Pragma","No-cache");

response.setHeader("Cache-Control","no-cache");

response.setDateHeader("Expires",0);

// 在内存中创建图象

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(getRandColor(200,250));

g.fillRect(0,width,height);

//设定字体

g.setFont(new Font("Times New Roman",Font.PLAIN,18));

//画边框

//g.setColor(new Color());

//g.drawRect(0,width-1,height-1);

// 随机产生155条干扰线,使图象中的认证码不易被其它程序探测到

g.setColor(getRandColor(160,200));

for (int i = 0; i < 100; 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);

System.out.println(rand);

}

// 将认证码存入SESSION

session.setAttribute("code",sRand);

// 图象生效

g.dispose();

// 输出图象到页面

ImageIO.write(image,"JPEG",response.getOutputStream());

%>

ajax动态验证页面

codevalidate.jsp

String path = request.getContextPath();

String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/";

%>

String authcode=request.getParameter("authcode");

String code=(String)session.getAttribute("code");

if(authcode.equals(code)){

out.println("

");}

else{

out.println("

验证码不正确
");}

%>

希望本文所述对大家JSP程序设计有所帮助。

总结

如果觉得编程之家网站内容还不错,欢迎将编程之家网站推荐给程序员好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。

如您喜欢交流学习经验,点击链接加入交流1群:1065694478(已满)交流2群:163560250

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值