最近的项目要求有验证码,从网上找了一些资料,有些很清楚,但是,那些例子都是用servlet做的,而此时我的项目是用struts框架做的,有点地方需要修改。
这次完成验证码有点小的教训,就像小叶说的,不能依赖性太大,我就是属于那种依赖性比较大的。因此,问了别人后,人家给解释后,后悔了……因为听人家一解释发现,自己也能咂摸过来这个道理呀……不过,还是很感谢csdn小鬼。
好了,言归正传,说说实现功能:
就是验证码的功能,首先,产生验证码是通过servlet实现,然后将生成的验证码放到一个session里面,之后,在jsp页面显示生成的图形,提交后,通过执行action,从session中提取出验证码,与输入的相比较,完成最后的验证。改进之处在于,查到的那些都是用的servlet,但是,我提交后不能用servlet了,要用struts2.
一、首先是servlet生成验证码并存储在session里面:(http://fayaa.com/code/view/8922/full/)
- packagecom.servlet;
- importjava.awt.Color;
- importjava.awt.Font;
- importjava.awt.Graphics;
- importjava.awt.image.BufferedImage;
- importjava.io.IOException;
- importjava.util.Random;
- importjavax.imageio.ImageIO;
- importjavax.servlet.ServletException;
- importjavax.servlet.ServletOutputStream;
- importjavax.servlet.http.HttpServlet;
- importjavax.servlet.http.HttpServletRequest;
- importjavax.servlet.http.HttpServletResponse;
- importjavax.servlet.http.HttpSession;
- publicclassImageServletextendsHttpServlet{
- privatestaticfinallongserialVersionUID=1L;
- publicvoiddoGet(HttpServletRequestrequest,HttpServletResponseresponse)
- throwsServletException,IOException{
- doPost(request,response);
- }
- publicvoiddoPost(HttpServletRequestrequest,HttpServletResponseresponse)
- throwsServletException,IOException{
- intwidth=80;//验证码图片宽度
- intheight=30;//验证码图片高度
- BufferedImageimage=newBufferedImage(width,height,BufferedImage.TYPE_3BYTE_BGR);
- Graphicsg=image.getGraphics();
- Randomrandom=newRandom();//创建一个随机类
- g.setColor(getRandColor(200,250));//背景颜色要偏淡
- g.fillRect(0,0,width,height);//画背景
- g.setColor(getRandColor(0,255));//边框颜色
- g.drawRect(0,0,width-1,height-1);//画边框
- g.setColor(getRandColor(160,200));//随机产生5条干扰线,使图象中的认证码不易被其它程序探测到
- for(inti=0;i<8;i++){
- intx=random.nextInt(width);
- inty=random.nextInt(height);
- intx1=random.nextInt(width);
- inty1=random.nextInt(height);
- g.drawLine(x,y,x1,y1);
- }
- g.setColor(getRandColor(160,200));//随机产生100点,使图象中的认证码不易被其它程序探测到
- for(inti=0;i<100;i++){
- intx=random.nextInt(width);
- inty=random.nextInt(height);
- g.drawLine(x,y,x,y);
- }
- Fontfont=newFont("TimesNewRoman",Font.ITALIC,26);//创建字体,字体的大小应该根据图片的高度来定。
- g.setFont(font);//设置字体
- intlength=4;//设置默认生成4个验证码
- Strings="abcdefghijklmnopqrstuvwxyz0123456789";//设置备选验证码:包括"a-z"和数字"0-9"
- StringsRand="";
- //用随机产生的颜色将验证码绘制到图像中。
- //生成随机颜色(因为是做前景,所以偏深)
- //调用函数出来的颜色相同,可能是因为种子太接近,所以只能直接生成
- g.setColor(newColor(20+random.nextInt(110),20+random.nextInt(110),20+random.nextInt(110)));
- for(inti=0;i<length;i++){
- Stringch=String.valueOf(s.charAt(random.nextInt(s.length())));
- sRand+=ch;
- g.drawString(ch,12*i+12,(random.nextInt(5)-2)*i+20);
- }
- //将生成的字符串存储在session中
- HttpSessionsession=request.getSession();
- session.setAttribute("checkCode",sRand);
- g.dispose();//图像生效
- //禁止图像缓存
- response.setHeader("Pragma","No-cache");
- response.setHeader("Cache-Control","no-cache");
- response.setDateHeader("Expires",0);
- response.setContentType("image/jpeg");
- //创建二进制的输出流
- ServletOutputStreamsos=response.getOutputStream();
- //将图像输出到Servlet输出流中。
- ImageIO.write(image,"jpeg",sos);
- sos.flush();
- sos.close();
- }
- publicColorgetRandColor(intlower,intupper){
- Randomrandom=newRandom();
- if(upper>255)
- upper=255;
- if(upper<1)
- upper=1;
- if(lower<1)
- lower=1;
- if(lower>255)
- lower=255;
- intr=lower+random.nextInt(upper-lower);
- intg=lower+random.nextInt(upper-lower);
- intb=lower+random.nextInt(upper-lower);
- returnnewColor(r,g,b);
- }
- }
二、在jsp中显示,并添加js实现“看不清”操作
js的定义:
- <scriptlanguage="javascript">
- functionchangeImg(){
- vara=document.getElementById("mySpan");
- a.innerHTML='<imgalign="middle"src="ImageServlet"/><ahref="#"onclick="changeImg();">看不清</a>';
- }
jsp显示:(用到了struts2里面的标签,如果不用的话,直接将“s:”去掉)
- <s:form action="Login.action" name="form1" method="post">
- <tr><td>
- <spanstyle="color:black">Yanzheng:</span>
- <inputtype="text"id="verifyCode"name="txtyzm"size="6"/>
- <spanid="mySpan"><imgalign="middle"src="ImageServlet"/><a
- href="#"onclick="changeImg();">看不清</a></span>
- <spanstyle="color:red;"><s:propertyvalue="yanzheng"></s:property></span>
- </td>
- </tr>
- <s:/form>
三、struts.xml中的配置:
- <!--登录操作-->
- <actionname="Login"class="com.action.Login">
- <resultname="userslog">/weluser.jsp</result>
- <resultname="usersout">/index.jsp</result>
- <resultname="ff">/ff.jsp</result>
- </action>
四、在Login.java中完成验证码的判断(只显示验证码判断部分)
- public class Login extends ActionSupport{
- privateStringyanzheng;
- publicStringgetYanzheng(){
- returnyanzheng;
- }
- publicvoidsetYanzheng(Stringyanzheng){
- this.yanzheng=yanzheng;
- }
- privateStringtxtyzm=newString();
- publicStringgetTxtyzm(){
- returntxtyzm;
- }
- publicvoidsetTxtyzm(Stringtxtyzm){
- this.txtyzm=txtyzm;
- }
- publicStringgetUstatus(){
- returnustatus;
- }
- public String execute() throws IOException{
- //验证码
- StringvalidateC=newString();
- HttpServletResponseresponse=null;
- //将session里面的验证码提取出来
- HttpSessionsessions=ServletActionContext.getRequest().getSession();
- validateC=(String)sessions.getAttribute("checkCode");
- if(txtyzm.equals(validateC)){
- yanzheng="";
- }else{
- yanzheng="验证码有误";
- return"usersout";
- }
- }
这样的话,就可以在jsp页面返回验证码错误信息了。总的来时,产生验证码时用的servlet,验证的时候,放到了struts2框架。
记录一下啦~