判断验证码输入是否正确问题

TommyWu01 2013-04-24 10:25:33
我做了个登录界面login.jsp,用session获取Servlet中产生的验证码,打印出来一看,却是上一次产生的验证码
第一次打开login.jsp时,session取出的值是null;刷新一下页面,这时取出的值是上一次生成的验证码!
session取出的值都是上一次的值!这样无法达到验证的效果,肯请帮忙!谢谢!附代码!
这是Servlet的service方法,用于产生随机验证码!并将验证码放入Session中

package com.fk.util;

import java.awt.Color;
import java.awt.Font;
import java.awt.Graphics;
import java.awt.image.BufferedImage;
import java.io.ByteArrayOutputStream;
import java.io.IOException;
import java.util.Random;

import javax.imageio.ImageIO;
import javax.servlet.ServletException;
import javax.servlet.ServletOutputStream;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession;

/**
* 获得图片验证码
* @author Administrator
*
*/
public class GetImageCode extends HttpServlet {

private static final long serialVersionUID = 1L;

private static int WIDTH = 60;
private static int HEIGHT = 20;

public char[] generateCheckCode() {
// 定义验证码的字符表
String chars = "0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ";
char[] rands = new char[4];
for (int i = 0; i < 4; i++) {
int rand = (int) (Math.random() * 36);
rands[i] = chars.charAt(rand);
}
return rands;
}

public void drawRands(Graphics g, char[] rands) {
g.setColor(Color.BLACK);
g.setFont(new Font(null, Font.ITALIC | Font.BOLD, 18));
// 在不同的高度上输出验证码的每个字符
g.drawString("" + rands[0], 1, 17);
g.drawString("" + rands[1], 16, 15);
g.drawString("" + rands[2], 31, 18);
g.drawString("" + rands[3], 46, 16);
}

public void drawBackground(Graphics g) {
// 画背景
g.setColor(new Color(0xDCDCDC));
g.fillRect(0, 0, WIDTH, HEIGHT);
// 随机产生120个干扰点
for (int i = 0; i < 120; i++) {
int x = (int) (Math.random() * WIDTH);
int y = (int) (Math.random() * HEIGHT);
int red = (int) (Math.random() * 255);
int green = (int) (Math.random() * 255);
int blue = (int) (Math.random() * 255);
g.setColor(new Color(red, green, blue));
g.drawOval(x, y, 1, 0);
}
}

public void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
HttpSession session = request.getSession();
response.setContentType("image/jpeg");
ServletOutputStream sos = response.getOutputStream();

// 设置浏览器不缓存此图片
response.setHeader("Pragma", "No-cache");
response.setHeader("Cache-Control", "no-cache");
response.setDateHeader("Expires", 0);

// 创建内存图像并获得其图形上下文
BufferedImage image = new BufferedImage(WIDTH, HEIGHT,
BufferedImage.TYPE_INT_RGB);
Graphics g = image.getGraphics();

// 产生随机的验证码
char[] rands = generateCheckCode();

// 产生图像
drawBackground(g);
drawRands(g, rands);

// 结束图像的绘制过程,完成图像
g.dispose();

// 将图像输出到客户端
ByteArrayOutputStream bos = new ByteArrayOutputStream();
ImageIO.write(image, "JPEG", bos);
byte[] buf = bos.toByteArray();
response.setContentLength(buf.length);
sos.write(buf);
bos.close();
sos.close();

// 将当前验证码存入到session中
session.setAttribute("checkCode", new String(rands));
System.out.println(session.getAttribute("checkCode"));
}

public void doPost(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
doGet(request, response);
}

}



  <servlet>
<servlet-name>GetImageCode</servlet-name>
<servlet-class>com.fk.util.GetImageCode</servlet-class>
</servlet>
<servlet-mapping>
<servlet-name>GetImageCode</servlet-name>
<url-pattern>/GetImageCode</url-pattern>
</servlet-mapping>



<div class="control-group"> 
<label class="control-label">*验证码:</label>
<div class="controls" style="width: 350px;">
<input type="text" name="verifyCode" id="verifyCode" maxlength="20" />
<div id="code_div">
</div>
<div id="verifyCode_error"></div>
</div>
</div>


var bol5=false;
/**
* emailReg js验证
* V1.0
*/
$(function (){
var i=0;
//验证码
$("#verifyCode").blur(function(){
var verifyCode=$("#verifyCode").val();
if(i==0){
$("#code_div").html("<img alt=\"验证码\" id=\"safecode\" src=\"${ctx}/GetImageCode\">"+"<a href=\"javascript:changeCode();\" id=\"changCode\">看不清楚</a>");
i++;
}

if(verifyCode.replace(/(^\s*)|(\s*$)/g,"")==""){
bol5=false;
$("#verifyCode_error").attr("class","error_div").html("<img src='${ctx}/images/error_img2.gif' width=\"15px\" height=\"15px\"/>请输入验证码");
}else{
$.ajax({
type: "post",
url: "${ctx}/user.do?method=checkImgCode&imgCode="+verifyCode,
dataType: "json", /*这句可用可不用,没有影响*/
contentType: "application/json; charset=utf-8",
success: function (bol) {
if(!bol){
bol5=true;
$("#verifyCode_error").html("<img src='${ctx}/images/success_img.gif' width='16px' height='16px'/>");
}else{
bol5=false;
$("#verifyCode_error").attr("class","error_div").html("<img src='${ctx}/images/error_img2.gif' width='15px' height='15px'/>"+"验证码不正确");
}

},
error: function (XMLHttpRequest, textStatus, errorThrown) {
alert(errorThrown);
}
});


}
});


});

...全文
914 22 打赏 收藏 转发到动态 举报
写回复
用AI写文章
22 条回复
切换为时间正序
请发表友善的回复…
发表回复
独觞 2013-09-04
  • 打赏
  • 举报
回复
只是页面取出的和servlet生成的不对应 用用一个servlet判断就好了
独觞 2013-09-04
  • 打赏
  • 举报
回复
同样遇到这个问题 学习了
u011163492 2013-08-19
  • 打赏
  • 举报
回复
改完的源代码可不可以分享一下啊???这么光说也不明白啊……AJax刚学,就用前台验证吧???
齐岳 2013-04-28
  • 打赏
  • 举报
回复

有那么复杂么
zhulei0429 2013-04-28
  • 打赏
  • 举报
回复
页面加载后,用ajax去服务端读验证码并放到session中,ajax返回后显示在页面, 这样页面和session都有验证码,你想用什么方式验证都可以。
u010313503 2013-04-28
  • 打赏
  • 举报
回复
怎么那个麻烦啦!!!!! 直接用js 做一个随机数不简单点吗??? 是不是你们在追求验证的更高境界哦
TommyWu01 2013-04-28
  • 打赏
  • 举报
回复
引用 17 楼 shadowsick 的回复:
感觉很明显第一个请求的时候你的验证码还没生成吧,所以你的隐藏域是空的,应该先保证验证码先生成吧
确实还没生成,我就去读session了,是在焦点离开验证码输入框的时候才生成
小丑哥_V5 2013-04-28
  • 打赏
  • 举报
回复
感觉很明显第一个请求的时候你的验证码还没生成吧,所以你的隐藏域是空的,应该先保证验证码先生成吧
TommyWu01 2013-04-26
  • 打赏
  • 举报
回复
引用 12 楼 lgc8023 的回复:
避免缓存,url中传一个随机数random
已经加了一个时间戳了
TommyWu01 2013-04-26
  • 打赏
  • 举报
回复
引用 11 楼 qiuming007 的回复:
你还做了个异步验证啊,这么感觉你问的问题和你说已解决的答案,不一样呢?
我遇到的问题是,将保存在session中的checkCode放在了web端的隐藏域,然后想在web端判断验证码是否输入正确,这样导致第一次进入页面时获取session中的checkCode为null,因为我首先进入的是页面,然后在页面中的验证码输入框绑定了blur事件获取验证码并保存在session中。 我解决的方式是,获取验证码的方式不变,在提交表单的时候,通过Ajax将输入的验证码传入后台的check验证码方法,在check验证码方法中同时获取用户输入的验证码和session中的验证码,两者进行比较,如果相等则放回true,否则为false,然后web端得到true的话就进入注册程序,否则提示验证码输入错误同时自动更换验证码。 不知道这样处理是否合理?
TommyWu01 2013-04-25
  • 打赏
  • 举报
回复
引用 9 楼 HOORIYE 的回复:
在你的页面 <label class="control-label">*验证码:</label> <div class="controls" style="width: 350px;"> <input typ……
不需要这么复杂,我已经通过ajax,将页面输入的验证码传入后台进行验证,然后判断正确与否。正确则跳转页面并remove掉session中的checkCode,错误则提示错误并更换验证码。
lgc8023 2013-04-25
  • 打赏
  • 举报
回复
避免缓存,url中传一个随机数random
qiuming007 2013-04-25
  • 打赏
  • 举报
回复
你还做了个异步验证啊,这么感觉你问的问题和你说已解决的答案,不一样呢?
雨声咚咚 2013-04-24
  • 打赏
  • 举报
回复
在你的页面 <label class="control-label">*验证码:</label> <div class="controls" style="width: 350px;"> <input type="text" name="verifyCode" id="verifyCode" maxlength="20" /> <div id="code_div"> </div> <div id="verifyCode_error"></div> </div> </div> 的 <div id="code_div"> </div> 改为<image id="code_div" src="GetImageCode" > 然后后面的js验证不要了 重新生成一个Servlet 获取页面 <input type="text" name="verifyCode" id="verifyCode" maxlength="20" /> 的${verifyCode}值 与getsession.getAttribute("checkCode")值比较久可以了!相同就直接跳转ok了
TommyWu01 2013-04-24
  • 打赏
  • 举报
回复
引用 3 楼 fangmingshijie 的回复:
每次请求,加上时间戳
鼠标进入文本框后才生成验证码,第一次午时间戳 当点击图片更换验证码的时候再重新生成新的验证码,加了时间戳,代码如下:
 function changeCode(){      
	  var timenow = new Date().getTime();   
	  var safecode = document.getElementById("safecode");     
	  safecode.src="<%=request.getContextPath()%>/GetImageCode?d="+timenow;    
  } 
TommyWu01 2013-04-24
  • 打赏
  • 举报
回复
引用 6 楼 linsn007 的回复:
你页面应该有个<img src="GetImageCode/>标签啊,不然怎么显示验证码图片
上面代码js中第一行有这么一段jquery代码
var i=0;
      //验证码  
      $("#verifyCode").blur(function(){       
            var verifyCode=$("#verifyCode").val();    
            if(i==0){
                 $("#code_div").html("<img alt=\"验证码\" id=\"safecode\" src=\"${ctx}/GetImageCode\">"+"<a href=\"javascript:changeCode();\" id=\"changCode\">看不清楚</a>");
                 i++; 
            }......
linsn007 2013-04-24
  • 打赏
  • 举报
回复
你页面应该有个<img src="GetImageCode/>标签啊,不然怎么显示验证码图片
linsn007 2013-04-24
  • 打赏
  • 举报
回复
验证码是servlet生成的吧,得在页面显示的吧?在页面加载验证码servlet的时候就把生成的字符存到session里就可以了啊
xizhou704 2013-04-24
  • 打赏
  • 举报
回复
你应该提供一个servlet转发到这个jsp页面,在负责转发的servlet面页里把验证码存到session中。 而你直接访问jsp,session里还没有保存验证码,所以第一次就是null
  • 打赏
  • 举报
回复
每次请求,加上时间戳
加载更多回复(2)

81,091

社区成员

发帖
与我相关
我的任务
社区描述
Java Web 开发
社区管理员
  • Web 开发社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧