问题现象:登陆页面验证码,在一次更新后无法显示,后台没有错误日志,浏览器里code 200 没找到一点儿错误,就是不显示!!在本地开发环境正常!
。。。。。此处省略一下午的操作
问题原因:
生成验证码的图片使用的这段代码
ServletOutputStream out = null;
try { // 图像输出
out = response.getOutputStream();
ImageIO.write(bufferImg, "jpeg", out);
} catch (IOException e) {
try {
out.close();
} catch (IOException e1) {
e1.printStackTrace();
}
}
首先问题是ImageIO.write 使用了tomcat下的temp临时目录,这个在部署的时候删除了,导致无法显示;
然后就是,本来找不到零食目录时会报异常:
javax.imageio.IIOException: Can't create cache file!
at javax.imageio.ImageIO.createImageInputStream(ImageIO.java:361)
at javax.imageio.ImageIO.read(ImageIO.java:1351)
但是catch (IOException e)这个并没有捕获到这个异常,后台什么日志都没记录到,导致浪费了很长时间没发现,后来抄了一段别人的代码,里面是catch(Exception e)才注意到错误!!
解决方法:就是新建个temp目录就好了;
另外还可以通过ImageIO.setUseCache(false)设置,更改缓存策略,使用内存缓存,不使用文件目录缓存;或者ImageIO.setCacheDirectory(cacheDirectory),指定缓存目录
在更新后,登陆页面的验证码出现无法显示的问题,后台无错误日志,浏览器返回200状态码。问题源于ImageIO.write方法在部署时使用了被删除的temp目录,导致无法创建缓存文件。由于catch块只捕获IOException,未捕获到特定的IIOException,延误了问题定位。解决方案是创建新的temp目录,或者调整ImageIO的缓存策略。此外,使用更广泛的catch(Exception e)可以避免类似问题。
953

被折叠的 条评论
为什么被折叠?



