转至繁体中文版     | 网站首页 | 图文教程 | 资源下载 | 站长博客 | 图片素材 | 武汉seo | 武汉网站优化 | 
最新公告:     敏韬网|教学资源学习资料永久免费分享站!  [mintao  2008年9月2日]        
您现在的位置: 学习笔记 >> 图文教程 >> 站长学院 >> Web开发 >> 正文
JSP中图片验证的实现         ★★★★

JSP中图片验证的实现

作者:闵涛 文章来源:闵涛的学习笔记 点击数:768 更新时间:2009/4/23 10:55:23

  [前言]图片验证在有关注册和发表留言经常用到.我在此用jsp写了个.供大家参考. 其中 com.sun.image 不是java的标准包.需要另外下载.相关地址为

  httpjava.sun.comproductsjava-mediajai

  1. random.jsp (产生四位的随机字符,由0-9,a-z,A-Z构成.并把最终字符串放到session中保存以让后续页面验证真伪)

  代码如下

 

%@ page autoFlush=false import=java.util.,java.awt.,java.awt.image.,
com.sun.image.codec.jpeg.,java.util.%

%@ page import= contentType=texthtml; charset=gb2312%

%

String chose=
0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ;
char display[]={'0',' ','0',' ','0',' ','0'},ran[]={'0','0','0','0'},temp;
Random rand=new Random();
for(int i=0;i4;i++)

{
temp=chose.charAt(rand.nextInt(chose.length()));
display[i2]=temp;
ran[i]=temp;

}

 

String random=String.valueOf(display);
session.setAttribute(random,String.valueOf(ran));

%

%
out.clear();

response.setContentType(imagejpeg);

response.addHeader(pragma,NO-cache);

response.addHeader(Cache-Control,no-cache);

response.addDateHeader(Expries,0);

int width=47, height=15;

BufferedImage image = new BufferedImage(width, height, BufferedImage.TYPE_INT_RGB);

Graphics g = image.getGraphics();

以下填充背景颜色

g.setColor(Color.GREEN);

g.fillRect(0, 0, width, height);

设置字体颜色

g.setColor(Color.RED);

g.drawString(random,3,10);

g.dispose();

ServletOutputStream outStream = response.getOutputStream();

JPEGImageEncoder encoder =JPEGCodec.createJPEGEncoder(outStream);

encoder.encode(image);

outStream.close();

%

2. img.jsp (显示验证图片.由于本程序简单让验证程序也一并放在了一起)

  代码如下:
<%@ page contentType="text/html; charset=gb2312" language="java"%>

<%

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

String random=(String)session.getAttribute("random");
if(num!=null&&random!=null)

{

if(!num.equals(random))

{

out.println("<script>alert('验证码错误!请重试。')</script>");
out.println("<script>history.go(-1)</script>");
//response.sendRedirect("img.jsp");

}

else

{

out.println("<center>验证成功!</center>");

}

}

%>

<html>

<head>

<title>图片验证</title>

<meta http-equiv="Content-Type" content="text/html; charset=gb2312">

</head>
<body>

<form action="img.jsp" method="post">

<table>

<tr>

<td>

<input type="text" name="num" size=10>

</td>

<td>

<img src="random.jsp">

</td>

</tr>

</table>

<input type="submit" value="OK">

</form>

</body>

</html>

  说明:有兴趣的网友可以在此基础上增加图片的内容.比如让背景加上纹理.让字符位置歪斜以加大扫描程序的难度.大家有什么看法和建议,都可以回复中提出来....
 
作者:eliry     

 


没有相关教程
教程录入:mintao    责任编辑:mintao 
  • 上一篇教程:

  • 下一篇教程:
  • 【字体: 】【发表评论】【加入收藏】【告诉好友】【打印此文】【关闭窗口
      注:本站部分文章源于互联网,版权归原作者所有!如有侵权,请原作者与本站联系,本站将立即删除! 本站文章除特别注明外均可转载,但需注明出处! [MinTao学以致用网]
      网友评论:(只显示最新10条。评论内容只代表网友观点,与本站立场无关!)

    同类栏目
    · Web开发  · 网页制作
    · 平面设计  · 网站运营
    · 网站推广  · 搜索优化
    · 建站心得  · 站长故事
    · 互联动态
    更多内容
    热门推荐 更多内容
  • 没有教程
  • 赞助链接
    更多内容
    闵涛博文 更多关于武汉SEO的内容
    500 - 内部服务器错误。

    500 - 内部服务器错误。

    您查找的资源存在问题,因而无法显示。

    | 设为首页 |加入收藏 | 联系站长 | 友情链接 | 版权申明 | 广告服务
    MinTao学以致用网

    Copyright @ 2007-2012 敏韬网(敏而好学,文韬武略--MinTao.Net)(学习笔记) Inc All Rights Reserved.
    闵涛 投放广告、内容合作请Q我! E_mail:admin@mintao.net(欢迎提供学习资源)

    站长:MinTao ICP备案号:鄂ICP备11006601号-18

    闵涛站盟:医药大全-武穴网A打造BCD……
    咸宁网络警察报警平台