记录一个和诡异的BUG

Map<String, Object> map = Maps.newHashMap();
        if (key.equals(SignUtils.getKey(url))) {
            try {
                String path = request.getSession().getServletContext().getRealPath(url);
                String[] fv = path.split("\\.");
                File newFile = new File(fv[0]+"_sign.png");
//              用下面三行代码 生成的图片有延迟,就是生成完成几秒后才能访问,具体原因不明白
//                String newUrl = fv[0]+"_sign.png";
//                String newFilePath = request.getSession().getServletContext().getRealPath(newUrl);//fv[0]+"_sign.png";
//                File newFile = new File(newFilePath);
                File oldFile = new File(request.getSession().getServletContext().getRealPath(url));
                InputStream in = new FileInputStream(oldFile);
                byte[] b = IOUtils.toByteArray(in);
                b = ImageUtils.transferAlpha(ImageUtils.ByteToBufferedImage(b), 150, x, y, width, height, rotate);
                Files.write(b,newFile);

                map.put("result", true);
                map.put("url", SignUtils.getUrl()+newFile.getName());
            } catch (Exception e) {
                e.printStackTrace();
                map.put("result", false);
                map.put("message", "操作失败:"+e.getMessage());
            }
        } else {
            map.put("result", false);
            map.put("message", "非法操作");
        }
        response.flushBuffer();
        return map;

这个程序是把一个web目录下的图片进行抠图处理,然进行另外命名保存处理,然后返回新的图片的路径,结果用注释掉的三行马上访问就是访问不到,换一种写法就好了。
请看注释,其实两个获取的绝对路径是一模一样的,但是第二个(注释掉的代码)就是有延迟,要三四秒后才能访问到

猜你喜欢

转载自alyouge.iteye.com/blog/2315367