【问题标题】:Java Servlet post request not working with ServletFileUploadJava Servlet 发布请求不适用于 ServletFileUpload
【发布时间】:2016-01-19 01:56:19
【问题描述】:

我正在尝试创建一个 Servlet,它将接受一个简单的 POST 请求。我按照here 描述的方法,启动了服务器,它按预期显示了带有文本Hellofriend!的页面。

接下来,我用doPost 替换了doGet 方法,如here 所述。这是我的代码(大部分代码都被注释掉了):

package com.file.upload;

import java.io.IOException;
import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.File;
import java.util.Iterator;
import java.util.List;
import javax.activation.MimetypesFileTypeMap;

import org.apache.commons.fileupload.FileItem;
import org.apache.commons.fileupload.FileItemFactory;
import org.apache.commons.fileupload.FileUploadException;
import org.apache.commons.fileupload.disk.DiskFileItemFactory;
import org.apache.commons.fileupload.servlet.ServletFileUpload;
import org.apache.commons.io.FilenameUtils;


/**
 * Servlet implementation class HelloServlet
 */
@WebServlet("/Test")
public class Test extends HttpServlet {
    private static final long serialVersionUID = 1L;
    private boolean isMultipart;
    private String filePath;
    private int maxFileSize = 50 * 1024;
    private int maxMemSize = 4 * 1024;
    private File file ;

    public void init( ){
        // Get the file location where it would be stored.
        filePath = 
                getServletContext().getInitParameter("file-upload"); 
    }

    public void doPost(HttpServletRequest request, 
            HttpServletResponse response)
                    throws ServletException, java.io.IOException {
        // Check that we have a file upload request
        isMultipart = ServletFileUpload.isMultipartContent(request);
        response.setContentType("text/html");
        java.io.PrintWriter out = response.getWriter( );
        if( !isMultipart ){
            out.println("<html>");
            out.println("<head>");
            out.println("<title>Servlet upload</title>");  
            out.println("</head>");
            out.println("<body>");
            out.println("<p>No file uploaded</p>"); 
            out.println("</body>");
            out.println("</html>");
            return;
        }
        boolean isMultipart = ServletFileUpload.isMultipartContent(request);

        if (isMultipart) {
            FileItemFactory factory = new DiskFileItemFactory();
            ServletFileUpload upload = new ServletFileUpload(factory);

//          try {
//              List items = upload.parseRequest(request);
//              Iterator iterator = items.iterator();
//              while (iterator.hasNext()) {
//                  FileItem item = (FileItem) iterator.next();
//                  if (!item.isFormField()) {
//                      String fileName = item.getName();
//
//                      String root = getServletContext().getRealPath("/");
//                      File path = new File(root + "/fileuploads");
//                      if (!path.exists()) {
//                          boolean status = path.mkdirs();
//                      }
//
//                      File uploadedFile = new File(path + "/" + fileName);
//                      item.write(uploadedFile);
//                  }
//              }
//          } catch(Exception ex) {
//              System.out.println(ex);
//          }
        }
    }
}

代码在ServletFileUpload upload = new ServletFileUpload(factory); 行失败。这是我得到的错误堆栈:

如何解决这个错误?

编辑:Eclipse 显示错误日志:

------
STATUS
------
pluginId            org.eclipse.wst.server.core
pluginVersion       1.6.100.v201505132000
code                0
severity            4
message             HIDDEN
fingerprint         d680f315

Exception:org.eclipse.epp.internal.logging.aeri.ui.log.StandInStacktraceProvider$StandInException: HIDDEN
     at org.eclipse.core.internal.jobs.JobManager.endJob(JobManager.java:701)
     at org.eclipse.core.internal.jobs.WorkerPool.endJob(WorkerPool.java:105)
     at org.eclipse.core.internal.jobs.Worker.run(Worker.java:72)

------
REPORT
------
anonymousId         5eca4a19-ce2d-4492-b01b-0011f98c45ff
name                My Name
email               
comment             
eclipseBuildId      4.5.0.I20150603-2000
eclipseProduct      org.eclipse.epp.package.jee.product
javaRuntimeVersion  1.8.0_51-b16
osgiWs              cocoa
osgiOs              MacOSX
osgiOsVersion       10.10.5
osgiArch            x86_64
logMessage          false
ignoreSimilar       false

-------
BUNDLES
-------
name                org.eclipse.core.jobs
version             3.7.0.v20150330-2103

【问题讨论】:

  • 看看这个问题是否对你有用:stackoverflow.com/questions/32471642/multiple-file-upload/…
  • 错误堆栈与到目前为止发布的代码无关。 Tomcat 刚刚启动失败(通常是由于严重的 webapp 配置错误)。它甚至没有机会调用 servlet。发布完整的启动日志(请不要在屏幕截图中,这对搜索机器人不友好,只需将其发布在代码块中即可)。
  • 你能告诉我在哪里可以获得完整的启动日志吗?我贴的截图是谁的?它出现后立即消失(我以非常精确的时间截图)......
  • Eclipse 不保留日志文件。如果您通过 Servers 选项卡轻轻地启动/停止服务器,而不是在项目/servlet 上执行“运行方式”,则控制台应该保持不变。不过,至于你的最终目的是使用JSP+Servlet上传文件,你在这里研究的时候没有发现这个Q吗? stackoverflow.com/questions/2422468/…您似乎正在使用 Tomcat 8,但您正在获取旧版 Apache Commons FileUpload。
  • 是的,我通过服务器选项卡执行此操作,即窗口->视图->服务器,然后单击开始按钮,然后控制台日志在消失之前短暂显示,然后 Eclipse 警告它无法启动服务器。我查看了答案,但无法理解。我在哪里可以找到那个神器?

标签: java eclipse tomcat servlets post


【解决方案1】:
  1. 您的 servlet 不是线程安全的。

    doPost() 方法可以同时调用多次以服务多个传入请求。 servlet 类中不应有依赖请求数据的字段。

    在您的情况下,您将“isMultipart”作为字段和局部变量。应该没有这样的字段。

  2. 阅读Java Servlet specification。 Tomcat 8 实现了 Servlet 3.1。其“3.2 文件上传”章节涵盖了文件上传API。

    使用Apache Commons Fileupload 是可能的,但是如果有用于此任务的官方 Servlet API,为什么还要麻烦呢?

  3. 关闭 Tomcat 期间的 NullPointerException 堆栈跟踪与您的问题无关。

    您的测试 servlet 不在该堆栈跟踪中。特别是“代码在 ServletFileUpload upload = new ServletFileUpload(factory); 行失败。”你的问题中的陈述没有证据。其他事情正在发生。

    是的,我通过服务器选项卡执行此操作,即 Window->Views->Servers,然后单击开始按钮,然后该控制台日志会在消失前短暂显示

    当 Eclipse 启动 Tomcat(以及任何其他 java 应用程序)时,它会为其打开一个控制台视图。

    如果您在屏幕上找不到控制台视图,您可以使用 Window > Perspective > Reset Perspective 重置窗口布局,然后通过Window > Show View > Console手动打开它。请参阅Eclipse Workbench Tutorial(也可通过帮助菜单在本地获得)及其在Console view 上的页面

【讨论】:

  • 代码在 ServletFileUpload 上传失败 = new ServletFileUpload(factory);行。” - 我这么说是因为如果我注释掉那行,服务器会按预期启动。
  • 使用最新的 Tomcat 8、commons-io-2.4.jar、commons-fileupload-1.3.1.jar,无论有无该行,您的代码都适用于我。在其他地方寻找问题。您仍然没有提供实际的错误消息。
猜你喜欢
  • 1970-01-01
  • 2021-09-01
  • 1970-01-01
  • 1970-01-01
  • 2023-01-12
  • 2014-09-09
  • 1970-01-01
  • 1970-01-01
  • 2023-02-08
相关资源
最近更新 更多