解决异常:javax.imageio.IIOException: Can’t create output stream

问题描述:

今天突然发现系统登录页面的验证码不显示了,然后查看后台日志信息,竟然发现日志也不输出了,就怀疑是不是日志把磁盘塞满了,然后删除了tomcat日志,重启后输出一下异常信息:

javax.imageio.IIOException: Can’t create output stream!
at javax.imageio.ImageIO.write(ImageIO.java:1574)
at cn.dreamit.p1001.verifycode.util.VerifyCodeUtils.outputImage(VerifyCodeUtils.java:184)
at cn.dreamit.p1001.verifycode.controller.VerifyCodeController.generateVerifyCode(VerifyCodeController.java:74)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
at java.lang.reflect.Method.invoke(Method.java:498)
at org.springframework.web.method.support.InvocableHandlerMethod.doInvoke(InvocableHandlerMethod.java:205)
at org.springframework.web.method.support.InvocableHandlerMethod.invokeForRequest(InvocableHandlerMethod.java:133)
at org.springframework.web.servlet.mvc.method.annotation.ServletInvocableHandlerMethod.invokeAndHandle(ServletInvocableHandlerMethod.java:97)
at org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter.invokeHandlerMethod(RequestMappingHandlerAdapter.java:827)
at org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter.handleInternal(RequestMappingHandlerAdapter.java:738)
at org.springframework.web.servlet.mvc.method.AbstractHandlerMethodAdapter.handle(AbstractHandlerMethodAdapter.java:85)
at org.springframework.web.servlet.DispatcherServlet.doDispatch(DispatcherServlet.java:967)
at org.springframework.web.servlet.DispatcherServlet.doService(DispatcherServlet.java:901)
at org.springframework.web.servlet.FrameworkServlet.processRequest(FrameworkServlet.java:970)
at org.springframework.web.servlet.FrameworkServlet.doGet(FrameworkServlet.java:861)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:626)
at org.springframework.web.servlet.FrameworkServlet.service(FrameworkServlet.java:846)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:733)
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:231)
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166)
at org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:52)
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:193)
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166)
at cn.dreamit.dreamweb.websso.filter.AbstactSsoFilter.doFilter(AbstactSsoFilter.java:122)
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:193)
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166)


代码分析:

问题代码主要就是如下这一行:

ImageIO.write(image, “jpg”, os);

这个输出图片的代码基本就是默认设置,默认流输出的目录就是/tomcat/temp, 找个这个目录下看了下居然没有东西,但是追到最上层目录看了下原来是其他项目的日志文件把磁盘给塞满了,好了,至此问题找到。


解决方案:

1、确保在tomcat有temp目录,因为ImageIO.write()这一句默认是输出到tomcat下temp目录。

2、ImageIO.setCacheDirectory(cacheDirectory),设置其他的空间充足的目录作为缓存输出目录。

3、ImageIO默认是使用缓存目录,可以通过ImageIO.setUseCache(false)来设置,更改缓存策略,不使用文件目录缓存,使用内存缓存

4、不使用ImageIO,换成其它JDK方法
ImageIO.write(bi, “jpg”, baos);

例如:
JPEGImageEncoder imageEncoder = JPEGCodec.createJPEGEncoder(response.getOutputStream());
imageEncoder .encode(image);

猜你喜欢

转载自blog.csdn.net/datuanyuan/article/details/109033300