`
bruce198
  • 浏览: 234026 次
  • 性别: Icon_minigender_1
社区版块
存档分类
最新评论
阅读更多

我做webwork 的上传时候,上传功能正常实现,可是控制台输出异常信息:

java.lang.IllegalStateException: getReader() or getInputStream() called 

请问这个信息是什么意思啊,什么原因导致出现这个错误的?

 

 
09:27:42.906 INFO   [SocketListener0-0] com.opensymphony.webwork.dispatcher.DispatcherUtils.getSaveDir(DispatcherUtils.java:359) >16> Unable to find 'webwork.multipart.saveDir' property setting. Defaulting to javax.servlet.context.tempdir    
09:27:43.359 ERROR! [SocketListener0-0] com.opensymphony.webwork.dispatcher.DispatcherUtils.prepare(DispatcherUtils.java:394) >17> Error setting character encoding to 'UTF-8' - ignoring.    
java.lang.IllegalStateException: getReader() or getInputStream() called    
 at org.mortbay.jetty.servlet.ServletHttpRequest.setCharacterEncoding(ServletHttpRequest.java:602)    
 at javax.servlet.ServletRequestWrapper.setCharacterEncoding(ServletRequestWrapper.java:105)    
 at com.opensymphony.webwork.dispatcher.DispatcherUtils.prepare(DispatcherUtils.java:392)    
 at com.opensymphony.webwork.dispatcher.FilterDispatcher.doFilter(FilterDispatcher.java:160)    
 at org.mortbay.jetty.servlet.WebApplicationHandler$CachedChain.doFilter(WebApplicationHandler.java:821)    
 at com.opensymphony.webwork.dispatcher.ActionContextCleanUp.doFilter(ActionContextCleanUp.java:88)    
 at org.mortbay.jetty.servlet.WebApplicationHandler$CachedChain.doFilter(WebApplicationHandler.java:821)    
 at org.mortbay.jetty.servlet.WebApplicationHandler.dispatch(WebApplicationHandler.java:471)    
 at org.mortbay.jetty.servlet.ServletHandler.handle(ServletHandler.java:568)    
 at org.mortbay.http.HttpContext.handle(HttpContext.java:1530)    
 at org.mortbay.jetty.servlet.WebApplicationContext.handle(WebApplicationContext.java:633)    
 at org.mortbay.http.HttpContext.handle(HttpContext.java:1482)    
 at org.mortbay.http.HttpServer.service(HttpServer.java:909)    
 at org.mortbay.http.HttpConnection.service(HttpConnection.java:820)    
 at org.mortbay.http.HttpConnection.handleNext(HttpConnection.java:986)    
 at org.mortbay.http.HttpConnection.handle(HttpConnection.java:837)    
 at org.mortbay.http.SocketListener.handleConnection(SocketListener.java:245)    
 at org.mortbay.util.ThreadedServer.handle(ThreadedServer.java:357)    
 at org.mortbay.util.ThreadPool$PoolThread.run(ThreadPool.java:534)    
   
====新建 文本文档.txt    
===================C:\DOCUME~1\Z\LOCALS~1\Temp\Jetty_127_0_0_1_8080__\upload__146e3062_112ac37bbfb__8000_00000001.tmp    
===================新建 文本文档.txt    
09:27:48.437 INFO   [SocketListener0-0] com.opensymphony.webwork.interceptor.FileUploadInterceptor.intercept(FileUploadInterceptor.java:242) >22> Removing file up C:\DOCUME~1\Z\LOCALS~1\Temp\Jetty_127_0_0_1_8080__\upload__146e3062_112ac37bbfb__8000_00000001.tmp    
 

 

 

以下是Action代码:

 

 

 
public class FileUploadAction extends ActionSupport implements ModelDriven{    
   
    private File up;    
    private String upContentType;    
    private String upFileName;    
    private String filepath;    
    private FileUploadService fileuploadService;    
    private FileUpload fileinfo = new FileUpload();    
         
   
 public String execute() throws Exception {    
  if(up != null){    
  System.err.println("===="+upFileName);    
  FileUploadAction(up,upFileName);    
  }    
  return SUCCESS;    
 }    
 private String fileFileName;    
 public String FileUploadAction(File up,String upFileName) {    
   
  // 以下为保存文件,视情况修改    
  if (up.isFile()) {    
   //fileFileName = name;    
//   filename = file.getName();    
   fileFileName = upFileName;    
   FileOutputStream outputStream;    
   filepath = "E:/uploadfolder/";    
   System.out.println("==================="+up);    
   System.out.println("==================="+fileFileName);    
   fileinfo.setFileFilename(fileFileName);    
   fileinfo.setFilepath(filepath);    
   fileuploadService.insertFileInfo(fileinfo);    
   try {    
    outputStream = new FileOutputStream(filepath + fileFileName);    
   
    FileInputStream fileIn = new FileInputStream(up);    
   
    byte[] buffer = new byte[1024];    
   
    int len;    
   
    try {    
     while ((len = fileIn.read(buffer)) > 0) {    
      outputStream.write(buffer, 0, len);    
     }    
    } catch (IOException e) {    
   
     e.printStackTrace();    
    }    
   
    try {    
     fileIn.close();    
     outputStream.close();    
    } catch (IOException e) {    
   
     e.printStackTrace();    
    }    
   
   } catch (FileNotFoundException e) {    
   
    e.printStackTrace();    
   }    
   
  }    
  return fileFileName;    
 }    
 public void setUp(File up) {    
  this.up = up;    
 }    
 public void setUpContentType(String upContentType) {    
  this.upContentType = upContentType;    
 }    
 public void setUpFileName(String upFileName) {    
  this.upFileName = upFileName;    
 }    
 public Object getModel() {    
      
  return fileinfo;    
 }    
 public void setFileuploadService(FileUploadService fileuploadService) {    
  this.fileuploadService = fileuploadService;    
 }    
                  
} 
   

 


      这个问题曾发到过论坛里,可是被评为隐藏贴,还扣了我30分......到现在不知道为什么被评为隐藏......谁知道的话也帮我看看原因吧,我先谢过了。

 

转自:http://simpledev.iteye.com/blog/224818 

webwork上传异常分析:getReader() or getInputStream() call

在使用webwork-2.2.4.jar,xwork-1.2.1.jar时文件上传发生异常.

Java代码 复制代码
  1. 00:29:07.390 ERROR! [SocketListener0-1] com.opensymphony.webwork.dispatcher.DispatcherUtils.prepare(DispatcherUtils.java:394) >17> Error setting character encoding to 'UTF-8' - ignoring.   
  2. java.lang.IllegalStateException: getReader() or getInputStream() called   
  3.  at org.mortbay.jetty.servlet.ServletHttpRequest.setCharacterEncoding(ServletHttpRequest.java:602)   
  4.  at javax.servlet.ServletRequestWrapper.setCharacterEncoding(ServletRequestWrapper.java:105)   
  5.  at com.opensymphony.webwork.dispatcher.DispatcherUtils.prepare(DispatcherUtils.java:392)   
  6.  ...  
00:29:07.390 ERROR! [SocketListener0-1] com.opensymphony.webwork.dispatcher.DispatcherUtils.prepare(DispatcherUtils.java:394) >17> Error setting character encoding to 'UTF-8' - ignoring. java.lang.IllegalStateException: getReader() or getInputStream() called at org.mortbay.jetty.servlet.ServletHttpRequest.setCharacterEncoding(ServletHttpRequest.java:602) at javax.servlet.ServletRequestWrapper.setCharacterEncoding(ServletRequestWrapper.java:105) at com.opensymphony.webwork.dispatcher.DispatcherUtils.prepare(DispatcherUtils.java:392) ...

 
分析源码如下:
com.opensymphony.webwork.dispatcher.DispatcherUtils.java:394

Java代码 复制代码
  1. String encoding = null;   
  2.        if (Configuration.isSet(WebWorkConstants.WEBWORK_I18N_ENCODING)) {   
  3.            encoding = Configuration.getString(WebWorkConstants.WEBWORK_I18N_ENCODING);   
  4.        }   
  5. Locale locale = null;   
  6.        if (Configuration.isSet(WebWorkConstants.WEBWORK_LOCALE)) {   
  7.            locale = LocalizedTextUtil.localeFromString(Configuration.getString(WebWorkConstants.WEBWORK_LOCALE), request.getLocale());   
  8.        }   
  9.   
  10.        if (encoding != null && !MultiPartRequest.isMultiPart(request)) {   
  11.            try {   
  12.                request.setCharacterEncoding(encoding);   
  13.            } catch (Exception e) {   
  14.                LOG.error("Error setting character encoding to '" + encoding + "' - ignoring.", e);   
  15.            }   
  16.        }  
String encoding = null; if (Configuration.isSet(WebWorkConstants.WEBWORK_I18N_ENCODING)) { encoding = Configuration.getString(WebWorkConstants.WEBWORK_I18N_ENCODING); } Locale locale = null; if (Configuration.isSet(WebWorkConstants.WEBWORK_LOCALE)) { locale = LocalizedTextUtil.localeFromString(Configuration.getString(WebWorkConstants.WEBWORK_LOCALE), request.getLocale()); } if (encoding != null && !MultiPartRequest.isMultiPart(request)) { try { request.setCharacterEncoding(encoding); } catch (Exception e) { LOG.error("Error setting character encoding to '" + encoding + "' - ignoring.", e); } }

 
webwork.properties

Xml代码 复制代码
  1. webwork.locale=en_US  
  2. webwork.i18n.encoding=UTF-8  
webwork.locale=en_US webwork.i18n.encoding=UTF-8

 
文件上传经过控制层处理时,得到的文件file对象,文件类型ContentType,文件名FileName都是正确的,文件名中文显示正常.

为了避免上面webwork抛出的异常,我们可以使用低版本的webwork(webwork-2.2.2.jar,xwork-1.1.3.jar)
运行程序之后系统没有抛出"java.lang.IllegalStateException: getReader() or getInputStream() called",但是文件名如果是中文为乱码,
为了解决文件名中文乱码问题,我们可以采取两种简单的处理方法:
  //方法一:获取文件后缀名
  //优点:使用RandomStringUtils随机生成10位字符为文件名,可以避免上传后存在文件名同名情况

Java代码 复制代码
  1. int idx = file4FileName.indexOf(".");   
  2. String suffix = fileFileName.substring(idx);   
  3. System.out.println(suffix);   
  4. String prefix = org.apache.commons.lang.RandomStringUtils.randomAlphabetic(10);   
  5. String filename = prefix + suffix;   
  6. System.out.println(filename);   
  7. fileFileName = filename;  
int idx = file4FileName.indexOf("."); String suffix = fileFileName.substring(idx); System.out.println(suffix); String prefix = org.apache.commons.lang.RandomStringUtils.randomAlphabetic(10); String filename = prefix + suffix; System.out.println(filename); fileFileName = filename;

 
  
  //方法二:字符串转码
  //使用上传的文件名,将乱码中文名转码(UTF-8),

Java代码 复制代码
  1. String filename2 = new String(fileFileName.getBytes(),"UTF-8");   
  2. System.out.println("filename2:"+filename2);   
  3. fileFileName = filename2;  
String filename2 = new String(fileFileName.getBytes(),"UTF-8"); System.out.println("filename2:"+filename2); fileFileName = filename2;

 
将该问题解决。(注:默认已使用webwork上传图片而出现上面异常时分析,具体上传代码略)

 

 

 

 

 

 

 

分享到:
评论

相关推荐

    webwork2.2.7在action中利用commons-fileupload.jar进行上传或直接读取文件流的配置与源代码及实例详解

    关键是正对最新版webwork,在action中进行操作,说得很细致,有源代码实例。也将异常情况处理列出来了。

    springMVC学习

    它可以与其它流行的 web 框架像 Struts、WebWork、JavaServer Faces 及 Tapestry 实现无缝集成。 SpringMVC 的生命周期可以拆解为六个步骤: 1. 客户端向 Spring 容器发起一个 HTTP 请求 2. 发起的请求被前端控制...

    SSH 框架所需JAR包

    1.commons-fileupload.jar(commons项目中的关于文件上传的包, struts2.1.6版本后必须加入此文件) 2.commons-io.jar(commons项目(commons项目就是java中一些常用的公共的组件)的io子项目,是处理异常的) 3....

    SSH 项目 整合jar包

    1.commons-fileupload.jar(commons项目中的关于文件上传的包, struts2.1.6版本后必须加入此文件) 2.commons-io.jar(commons项目(commons项目就是java中一些常用的公共的组件)的io子项目,是处理异常的) 3....

    web项目常用jar包及说明.zip

    1.commons-fileupload.jar(commons项目中的关于文件上传的包, struts2.1.6版本后必须加入此文件) 2.commons-io.jar(commons项目(commons项目就是java中一些常用的公共的组件)的io子项目,是处理异常的) 3....

    Spring-Reference_zh_CN(Spring中文参考手册)

    13.8. Spring对分段文件上传(multipart file upload)的支持 13.8.1. 介绍 13.8.2. 使用MultipartResolver 13.8.3. 在表单中处理分段文件上传 13.9. 使用Spring的表单标签库 13.9.1. 配置标签库 13.9.2. form标签 ...

    Spring 2.0 开发参考手册

    15.6. WebWork 15.7. 更多资源 16. Portlet MVC框架 16.1. 介绍 16.1.1. 控制器 - MVC中的C 16.1.2. 视图 - MVC中的V 16.1.3. Web作用范围的Bean 16.2. DispatcherPortlet 16.3. ViewRendererServlet 16.4....

    Spring中文帮助文档

    15.6. WebWork 15.7. 更多资源 16. Portlet MVC框架 16.1. 介绍 16.1.1. 控制器 - MVC中的C 16.1.2. 视图 - MVC中的V 16.1.3. Web作用范围的Bean 16.2. DispatcherPortlet 16.3. ViewRendererServlet 16.4....

    Spring API

    15.6. WebWork 15.7. 更多资源 16. Portlet MVC框架 16.1. 介绍 16.1.1. 控制器 - MVC中的C 16.1.2. 视图 - MVC中的V 16.1.3. Web作用范围的Bean 16.2. DispatcherPortlet 16.3. ViewRendererServlet 16.4....

    spring chm文档

    15.6. WebWork 15.7. 更多资源 16. Portlet MVC框架 16.1. 介绍 16.1.1. 控制器 - MVC中的C 16.1.2. 视图 - MVC中的V 16.1.3. Web作用范围的Bean 16.2. DispatcherPortlet 16.3. ViewRendererServlet 16.4....

    webx3框架指南PDF教程附学习Demo

    • Webwork • Tapestry • Spring MVC 以上框架都是非常优秀的。说实话,如果阿里巴巴网站在2001年开始,就有这么多可选择的话,无论选择哪一个都不会有问题。因为这些年来,所有的开源Web框架都在互相学习、并...

Global site tag (gtag.js) - Google Analytics