Jsp生成页面验证码的方法[附代码]

2016-02-19 11:15 27 1 收藏

清醒时做事,糊涂时读书,大怒时睡觉,无聊时关注图老师为大家准备的精彩内容。下面为大家推荐Jsp生成页面验证码的方法[附代码],无聊中的都看过来。

【 tulaoshi.com - Web开发 】

image.jsp------------------------------生成随机验证码图片的Jsp页面
代码如下: 
代码如下:

%@ page contentType="image/jpeg" import="java.awt.*,
java.awt.image.*,java.util.*,javax.imageio.*" %
%!
Color getRandColor(int fc,int bc)
{
Random random = new Random();
if(fc255) fc=255;
if(bc255) 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);
}
%
%
out.clear();//这句针对resin服务器,如果是tomacat可以不要这句
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, 0, width, height);
g.setFont(new Font("Times New Roman",Font.PLAIN,18));
g.setColor(getRandColor(160,200));
for (int i=0;i155;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);
}
String sRand="";
for (int i=0;i4;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);
}
// 将认证码存入SESSION
session.setAttribute("rand",sRand);
g.dispose();
ImageIO.write(image, "JPEG", response.getOutputStream());
%

logic.jsp--------------------------------登陆页面,在这里提供输入验证码然后提交并验证
代码如下: 
代码如下:

%@ page contentType="text/html;charset=gbk" %
%@ page language="java" import="java.sql.*" errorPage="" %
html
head
meta http-equiv="Content-Type" content="text/html; charset=gb2312"
title用户登录/title
script language="javascript"
function loadimage(){
document.getElementById("randImage").src = "image.jsp?"+Math.random();
}
/script
/head
body
table width="256" cellpadding="0" cellspacing="0"
!--DWLayoutTable--
form action="validate.jsp" method="post" name="loginForm"
tr
td width="118" height="22" valign="middle" style="text-align:center"input type="text" name="rand" size="15"/td
td width="138" valign="middle" style="text-align:center"img alt="" name="randImage" id="randImage" src="image.jsp" width="60" height="20" align="absmiddle"/td
/tr
tr
td height="36" colspan="2" style="text-align:center" valign="middle"a href="javascript:loadimage();"font class=pt95看不清点我/font/a/td
/tr
tr
td height="36" colspan="2" style="text-align:center" valign="middle"input type="submit" name="login" value="提交"/td
/tr
/form
/table
/body
/html

validate.jsp--------------------------用来验证输入的验证码是否正确
代码如下:
代码如下:

%@ page contentType="text/html; charset=gb2312" language="java" import="java.sql.*" errorPage="" %
%
String rand = (String)session.getAttribute("rand");
String input = request.getParameter("rand");
if(rand.equals(input)){
out.print("scriptalert('验证通过!');/script");
} else{
out.print("scriptalert('请输入正确的验证码!');location.href='login.jsp';/script");
}
%

以上三个JSP页面放在和WEB-INF同级目录下,如果你放在不同的文件夹下,那么里面相关页面的路径自己稍作更改就可以了。
友情提示:Tomcat5以下版本会出现异常

来源:https://www.tulaoshi.com/n/20160219/1596841.html

延伸阅读
标签: ASP
      这个程序主要是先生成一个随机数,然后根据生成的随机数经过变换后作为XBM图片的内容,最后显示这个图片. 验证时中要获取输入的数字和Session("validatecode")比较,如果相等则通过验证(还要注意一下相比较的两数据的类型保持一致)。 如何显示生成的图片呢?  xbm.asp的代码如下 程序代码: ...
标签: PHP
  效果参考(附源码)http://mail.htjs.net/yanzhengma/test.php <?session_start (); ? <FORM METHOD=POST ACTION="" <input type=text name=number maxlength=4<img src="http://img.jcwcn.com/attachment/portal" <INPUT TYPE="submit" name="sub" </FORM <? //检验校验码 if(isset( $HTTP...
代码如下: makeCertPic.java package pic; import java.awt.Color; import java.awt.Font; import java.awt.Graphics; import java.awt.image.BufferedImage; import java.io.IOException; import java.io.OutputStream; import java.util.Random; import javax.imageio.ImageIO; /** * @autho...
标签: Web开发
我们在做验证码的时候往往由于要反作弊,验证有时故意加入多的干扰因素,这时验证码显示不很清楚,用户经常输入错误。这样不但要重新刷新页面,导致用户没有看清楚验证码而重填而不是修改,而且如果没有用session保存下用户输入的其它数据的话(如姓名),用户刚刚输入的内容也不存在了,这样给用户造成不好的体验。 本例在原有验证方式基础之上增...
 Ajax(asynchronous javascript and xml)异步的javascript和xml.     是为了解决传统的web应用中"发送请求-等待响应"这种模式的弊端,(浏览器在发送完请求后,只能等待服务器的响应,用户不能做其他的操作,浏览器发送完请求,会抛弃整个页面,等待服务器返回新的页面,也就是说,浏览器和服务器之间交互...

经验教程

868

收藏

30
微博分享 QQ分享 QQ空间 手机页面 收藏网站 回到头部