本站首页    管理页面    写新日志    退出


«October 2025»
1234
567891011
12131415161718
19202122232425
262728293031


公告
 本博客在此声明所有文章均为转摘,只做资料收集使用。

我的分类(专题)

日志更新

最新评论

留言板

链接

Blog信息
blog名称:
日志总数:1304
评论数量:2242
留言数量:5
访问次数:7641475
建立时间:2006年5月29日




[J2SE]网站验证码的若干问题
软件技术,  电脑与网络

lhwork 发表于 2006/6/12 15:00:02

 显示附加码的主要问题是能够在不支持XWindows的linux环境下显示图片,毕竟大型的网站是基于linux操作系统,同时一般不会安装XWindow。Linux下的JDK1.4中的awt功能,要用到 XWindow 的一些库,所以需要安装。如果你使用的是JDK1.5 + Tomcat,就不会有这个问题,JDK1.5重写awt库了。如果是在linux或者unix下面使用验证码,用xwindows启动系统,启动tomcat,可以解决在linux下面不能显示验证码的问题。可以使用export JAVA_OPTS="-Djava.awt.headless=true",在catalina.sh中增加CATALINA_OPTS="$CATALINA_OPTS -Djava.awt.headless=true"在启动Weblogic中要加上这个参数-Djava.awt.headless=true,这样才能显示出图片。在JDK1.4可以在代码中增加:System.setProperty("java.awt.headless", "true");这样就不用xWindow库的支持了。如果出现tomcat的log中有异常:StandardWrapperValve[jsp]: Servlet.service() for servlet jsp threw exceptionorg.apache.jasper.JasperException: getOutputStream() has already been called for this response这是因为apache的jasper2已经在翻译jsp为servlet时,已经调用了了this response的getWriter,你再调用getOutputStream()时,就抛出这个异常。注意,weblogic和resin的HttpResponse实现没有遵循sun的标准,所以可以直接输出图片。如果显示不正常,加上out.clear();在weblogic中显示正常了。resin翻译的jsp可能产生几个空行,影响显示。附两个个例子import java.io.*;import javax.servlet.http.*;import javax.servlet.*;import java.util.*;import java.awt.*;import java.awt.image.*;import javax.imageio.*;//import com.sun.image.codec.jpeg.*;public class vImage extends HttpServlet{        public void init(ServletConfig conf) throws ServletException        {                super.init(conf);        }                public void doGet(HttpServletRequest req,HttpServletResponse res) throws ServletException, IOException        {                res.setContentType("image/jpeg");                res.setHeader("Pragma","No-cache");                res.setHeader("Cache-Control","no-cache");                res.setDateHeader("Expires", 0);                HttpSession session = req.getSession();                                // 在内存中创建图象                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(new Color());                //g.drawRect(0,0,width-1,height-1);                                // 随机产生155条干扰线,使图象中的认证码不易被其它程序探测到                g.setColor(getRandColor(160,200));                for (int i=0;i<155;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);                }                                // 将认证码存入SESSION                session.setAttribute("post_validate_code",sRand);                                // 图象生效                g.dispose();                                // 输出图象到页面                ImageIO.write(image, "JPEG", res.getOutputStream());                //JPEGImageEncoder encoder = JPEGCodec.createJPEGEncoder(res.getOutputStream());                //encoder.encode(image);        }                public void doPost(HttpServletRequest req,HttpServletResponse res) throws ServletException, IOException        {                doGet(req,res);        }                //给定范围获得随机颜色        private Color getRandColor(int fc,int bc)        {                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);    }}import java.io.*;import java.util.*;import com.sun.image.codec.jpeg.*;import javax.servlet.*;import javax.servlet.http.*;import java.awt.*;import java.awt.image.*;/*** Title: getImg.java* Description: 这个class主要实现随机生成一个4位数的验证码,并写入session,* Copyright: Copyright (c) 2003* Company: 蓝星软件* @author falcon* @version 1.1*/public class getImg extends HttpServlet {private Font mFont=new Font("宋体", Font.PLAIN,12);//设置字体//处理postpublic void doPost(HttpServletRequest request,HttpServletResponse response)throws ServletException,IOException {doGet(request,response);}public void doGet(HttpServletRequest request,HttpServletResponse response)throws ServletException,IOException {//取得一个1000-9999的随机数String s="";int intCount=0;intCount=(new Random()).nextInt(9999);//if(intCount<1000)intCount+=1000;s=intCount+"";//对session付值。HttpSession session=request.getSession (true);session.setAttribute("getImg",s);response.setContentType("image/gif");ServletOutputStream out=response.getOutputStream();BufferedImage image=new BufferedImage(35,14,BufferedImage.TYPE_INT_RGB);Graphics gra=image.getGraphics();//设置背景色gra.setColor(Color.yellow);gra.fillRect(1,1,33,12);//设置字体色gra.setColor(Color.black);gra.setFont(mFont);//输出数字char c;for(int i=0;i<4;i++) {c=s.charAt(i);gra.drawString(c+"",i*7+4,11); //7为宽度,11为上下高度位置}JPEGImageEncoder encoder=JPEGCodec.createJPEGEncoder(out);encoder.encode(image);out.close();}}


阅读全文(2112) | 回复(0) | 编辑 | 精华
 



发表评论:
昵称:
密码:
主页:
标题:
验证码:  (不区分大小写,请仔细填写,输错需重写评论内容!)



站点首页 | 联系我们 | 博客注册 | 博客登陆

Sponsored By W3CHINA
W3CHINA Blog 0.8 Processed in 0.063 second(s), page refreshed 144831388 times.
《全国人大常委会关于维护互联网安全的决定》  《计算机信息网络国际联网安全保护管理办法》
苏ICP备05006046号