`

错误日志

    博客分类:
  • JSP
阅读更多
开发环境:JDK1.4,Myeclipse6.6,WEB Logic8.1
出错记录:在WEB Logic后台报错如下:
Servlet failed with IOException
javax.imageio.IIOException: Can't create output stream !
[color=red][/color]
        at javax.imageio.ImageIO.write(ImageIO.java:1505)
        at com.sclh.common.ValidateCodeServlet.service(ValidateCodeServlet.java:
111)
        at javax.servlet.http.HttpServlet.service(HttpServlet.java:853)
        at weblogic.servlet.internal.ServletStubImpl$ServletInvocationAction.run
(ServletStubImpl.java:996)
        at weblogic.servlet.internal.ServletStubImpl.invokeServlet(ServletStubIm
pl.java:419)
        at weblogic.servlet.internal.ServletStubImpl.invokeServlet(ServletStubIm
pl.java:315)
        at weblogic.servlet.internal.WebAppServletContext$ServletInvocationActio
n.run(WebAppServletContext.java:6452)
        at weblogic.security.acl.internal.AuthenticatedSubject.doAs(Authenticate
dSubject.java:321)
        at weblogic.security.service.SecurityManager.runAs(SecurityManager.java:
118)
        at weblogic.servlet.internal.WebAppServletContext.invokeServlet(WebAppSe
rvletContext.java:3661)
        at weblogic.servlet.internal.ServletRequestImpl.execute(ServletRequestIm
pl.java:2630)
        at weblogic.kernel.ExecuteThread.execute(ExecuteThread.java:219)
        at weblogic.kernel.ExecuteThread.run(ExecuteThread.java:178)
Caused by: javax.imageio.IIOException: Can't create cache file!
        at javax.imageio.ImageIO.createImageOutputStream(ImageIO.java:395)
        at javax.imageio.ImageIO.write(ImageIO.java:1503)
        ... 12 more
Caused by: java.io.IOException: 系统找不到指定的路径。
        at java.io.WinNTFileSystem.createFileExclusively(Native Method)
        at java.io.File.checkAndCreate(File.java:1314)
        at java.io.File.createTempFile(File.java:1402)
        at javax.imageio.stream.FileCacheImageOutputStream.<init>(FileCacheImage
OutputStream.java:66)
        at com.sun.imageio.spi.OutputStreamImageOutputStreamSpi.createOutputStre
amInstance(OutputStreamImageOutputStreamSpi.java:50)
        at javax.imageio.ImageIO.createImageOutputStream(ImageIO.java:391)
        ... 13 more

在网上查了一下:有二个答案
1:Tomcat下创建一个临时目录temp,可惜我用的是Web Logic,只有用第二个方法了.
2 把代码最后一句改为:
//将图像输出到Servlet输出流中。
  
/*ServletOutputStream sos = response.getOutputStream();
   ImageIO.write(buffImg, "jpeg", sos);   
   sos.close();*/   
   JPEGImageEncoder encoder = JPEGCodec.createJPEGEncoder(response.getOutputStream());
   encoder.encode(buffImg);



代码如下:
public class ValidateCode extends HttpServlet { 
 public void service(HttpServletRequest request, HttpServletResponse response)
               throws ServletException, java.io.IOException {   
    HttpSession session = (HttpSession) request.getSession();
    String action = request.getParameter("action");
    if("getSession".equals(action)){
     String validateCodeSession = (String) session.getAttribute("validateCode");
   PrintWriter out = response.getWriter();
   response.setContentType("text/html");
   response.setHeader("Cache-Control", "no-cache");
   out.print(validateCodeSession);
   out.close();
    }else{
     if(session.getAttribute("validateCode") != null){
      session.removeAttribute("validateCode");
     }
            //验证码图片的宽度。
   int width = 120;
   //验证码图片的高度。
   int height = 30;
   //验证码字符个数
   int codeCount = 4;
   int x_v = 0;
   //字体高度
   int fontHeight;
   int codeY;
   char[] codeSequence = { 'A', 'B', 'C', 'D', 'E', 'F', 'G', 'H',
     'I', 'J', 'K', 'L', 'M', 'N', 'O', 'P', 'Q', 'R', 'S', 'T',
     'U', 'V', 'W', 'X', 'Y', 'Z', '0', '1', '2', '3', '4', '5',
     '6', '7', '8', '9' };
   //初始化图片大小
   x_v = width / (codeCount + 1);
   fontHeight = height - 2;
   codeY = height - 4;
   //定义图像buffer
   BufferedImage buffImg = new BufferedImage(width, height,
     BufferedImage.TYPE_INT_RGB);
   Graphics2D g = buffImg.createGraphics();
   //创建一个随机数生成器类
   Random random = new Random();
   //将图像填充为白色
   g.setColor(Color.WHITE);
   g.fillRect(0, 0, width, height);
   //创建字体,字体的大小应该根据图片的高度来定。
   Font font = new Font("Arial", Font.BOLD, fontHeight);
   //设置字体。
   g.setFont(font);
   //画边框。
   g.setColor(Color.WHITE);
   g.drawRect(0, 0, width - 1, height - 1);
   //随机产生160条干扰线,使图象中的认证码不易被其它程序探测到。
   g.setColor(Color.yellow);
   for (int i = 0; i < 30; 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);
   }
   //randomCode用于保存随机产生的验证码,以便用户登录后进行验证。
   StringBuffer randomCode = new StringBuffer();
   int red = 0, green = 0, blue = 0;
   //随机产生codeCount数字的验证码。
   for (int i = 0; i < codeCount; i++) {
    //得到随机产生的验证码数字。
    String strRand = String
      .valueOf(codeSequence[random.nextInt(36)]);
    //产生随机的颜色分量来构造颜色值,这样输出的每位数字的颜色值都将不同。
    red = random.nextInt(255);
    green = random.nextInt(255);
    blue = random.nextInt(255);
    //用随机产生的颜色将验证码绘制到图像中。
    g.setColor(new Color(red, green, blue));
    g.drawString(strRand, (i + 1) * x_v, codeY);
    //将产生的四个随机数组合在一起。
    randomCode.append(strRand);
   }
   // 将四位数字的验证码保存到Session中。
   session.setAttribute("validateCode", randomCode.toString());
   // 禁止图像缓存。
   response.setHeader("Pragma", "no-cache");
   response.setHeader("Cache-Control", "no-cache");
   response.setDateHeader("Expires", 0);
   response.setContentType("image/jpeg");
   //将图像输出到Servlet输出流中。
   /*ServletOutputStream sos = response.getOutputStream();
   ImageIO.write(buffImg, "jpeg", sos);   
   sos.close();*/
   
   JPEGImageEncoder encoder = JPEGCodec.createJPEGEncoder(response.getOutputStream());
   encoder.encode(buffImg);

          }
     }
}


Web.xml内容如下:
   
 <servlet>
     <servlet-name>ValidateCode </servlet-name>   
     <servlet-class>com.ValidateCode </servlet-class>
    </servlet>

     <servlet-mapping>
     <servlet-name>ValidateCode </servlet-name>
     <url-pattern>/ValidateCode</url-pattern>
    </servlet-mapping>


JSP内容如下:
<img src="/ValidateCode " id="ImgId" width="120" height="30" />



分享到:
评论

相关推荐

    tomcat控制台详细错误日志设置

    为了帮助开发者更好地理解并解决这些问题,我们可以调整Tomcat的配置,使其输出更详细的错误日志。本篇文章将详细介绍如何进行这样的设置。 1. **启用Tomcat的详细错误日志** Tomcat的错误日志主要通过`logging....

    友盟统计上传错误日志

    友盟统计上传错误日志是移动应用开发中一个常见的实践,用于收集并分析应用程序运行时出现的异常和错误,帮助开发者及时发现并修复问题,确保APP的稳定性和用户体验。友盟是中国领先的移动开发者服务提供商,提供了...

    软件开发错误日志

    在软件开发过程中,错误日志是开发者不可或缺的工具,它记录了程序运行时出现的问题,帮助定位和修复错误。下面将详细阐述“软件开发错误日志”中的几个关键知识点。 首先,错误名称添加失败通常意味着在尝试记录或...

    SQL Server数据库状态监控 – 错误日志

    在SQL Server数据库管理中,错误日志扮演着至关重要的角色,它是系统监控和故障排查的重要工具。错误日志记录了数据库服务器在运行过程中遇到的问题、警告以及重要事件,帮助管理员了解系统的健康状况,并在出现问题...

    20140927Eclipse错误日志

    20140927Eclipse错误日志

    错误日志收集

    在IT行业中,错误日志收集是一项至关重要的任务,它对于诊断和解决系统、应用程序或服务出现的问题具有不可估量的价值。错误日志是系统在运行过程中记录的各种异常、故障和警告信息,通过分析这些日志,我们可以定位...

    java swing用Logger输出错误日志.docx

    在Swing应用中,我们同样可以使用Java内置的`java.util.logging`包来输出错误日志。这篇文档主要讨论了如何在Java Swing应用中使用`Logger`来生成和管理错误日志。 `Logger`是Java的日志记录工具,它提供了多种级别...

    sybase 3414 错误解决方案 附带错误日志

    首先,我们需要分析错误日志,这是解决问题的第一步。`errorlog.zip`文件很可能包含了详细的错误信息,包括错误发生的时间、触发错误的操作以及可能的原因。通过解压缩并查看这个文件,我们可以获取到关键的线索。...

    sql server 查寻错误日志

    在日常运维和故障排查过程中,查看和分析SQL Server的错误日志是一项基本且关键的任务。通过深入理解并掌握SQL Server错误日志的查询方法,可以迅速定位问题,提升系统的可用性和响应速度。 ### SQL Server错误日志...

    android 错误日志的收集

    在Android开发过程中,错误日志的收集是诊断和解决问题的关键步骤。这有助于开发者理解应用程序运行时的异常情况,从而定位并修复潜在的问题。本篇内容将深入探讨Android错误日志的收集方法及其重要性。 首先,...

    监控错误日志并通过rabbitMq发送钉钉通知.docx

    监控错误日志并通过RabbitMQ发送钉钉通知是一种常见的日志管理和实时告警策略,尤其在大型分布式系统中。RabbitMQ是一个开源的消息代理和队列服务器,它用于路由和缓冲应用程序之间的消息,而钉钉则是一个企业级的...

    将android客户端的错误日志压缩上传到服务器

    在Android应用开发中,错误日志的收集与分析是至关重要的。这有助于开发者迅速定位和修复应用程序中的问题,提升用户体验。本教程将详细介绍如何实现一个功能,即从Android客户端将错误日志压缩并上传到服务器。这个...

    apache启动服务错误日志

    apache启动服务错误日志,有助于帮助开发者分析问题所在。

    .net写错误日志基本代码

    ### .NET中记录错误日志的基本方法 在.NET框架中,记录错误日志是一种非常重要的技术,它可以帮助开发者快速定位并解决问题。本文将基于提供的代码片段来详细解释如何在.NET中实现基本的错误日志记录功能。 #### ...

    我的错误日志,包括一些经验

    错误日志,包括hibernate与spring,jbpm

    C++ 错误日志 所在函数 所在行

    在C++编程中,错误日志是至关重要的,它能够帮助开发者在程序出错时快速定位问题,提高调试效率。本程序实现了一种错误日志系统,通过自定义宏,能够在发生错误时记录下错误发生的具体位置,包括所在函数、行数等...

    安装数据库出现“配置服务器失败参考服务器错误日志”解决办法

    安装SQL时最后出现 配置服务器失败参考服务器错误日志 ,很烦人,运行这个文件后很快解决,双击运行就行

    SANGFOR DLAN及防火墙常见错误日志和解决办法

    SANGFOR DLAN及防火墙常见错误日志和解决办法_20100526.pdf

    AIX操作系统错误日志及日常维护

    AIX 操作系统错误日志及日常维护 AIX 操作系统错误日志是系统管理员维护和排除系统故障的重要工具。系统错误日志记录了系统的各种故障信息,包括硬件、软件和其他操作信息。 一、系统故障记录 (errorlog) error...

Global site tag (gtag.js) - Google Analytics