更新
现在在另一台计算机上尝试它并且工作正常,我的玻璃鱼应该有问题,如果有人有想法而没有重新安装它我会很高兴。
END_UPDATE
我正在尝试创建一个接收文件并使用它执行某项操作的简单servlet,但即使使用最简单的示例,它也不适用于大于20mb的文件。
最大的问题是glassfish没有记录任何内容,而且错误根本没有显示任何异常,而且消息非常通用。
另一个重要的事情是,当文件大于20mb时,甚至不会调用doPost(),之前会抛出错误。
以下是显示的错误:
其他的是该消息显示HTTP状态500,但实际状态是400(错误请求)。
这是我正在使用的Servlet:
import java.io.IOException;
import java.util.Collection;
import javax.servlet.ServletException;
import javax.servlet.annotation.MultipartConfig;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.Part;
@WebServlet("/upload")
@MultipartConfig(location = "/tmp")
public class FileUploadServlet extends HttpServlet {
@Override
protected void doGet(HttpServletRequest req, HttpServletResponse res) throws ServletException, IOException {
getServletContext().getRequestDispatcher("/WEB-INF/views/upload.jsp").forward(req, res);
}
@Override
protected void doPost(HttpServletRequest req, HttpServletResponse res) throws ServletException, IOException {
Collection<Part> parts = req.getParts();
for(Part part : parts) {
System.out.println("Name:");
System.out.println(part.getName());
System.out.println("Header: ");
for(String headerName : part.getHeaderNames()) {
System.out.println(headerName);
System.out.println(part.getHeader(headerName));
}
System.out.println("Size: ");
System.out.println(part.getSize());
part.write(part.getName() + "-down");
}
res.sendRedirect("/upload");
}
}
这是简单的jsp(但是即使使用POST工具也会抛出错误,比如Postman):
<!doctype html>
<html>
<head>
<meta charset="UTF-8"/>
<title>File Upload Sample</title>
</head>
<body>
<form action="" enctype="multipart/form-data" method="post">
<p>
<label>Select a file: </label>
<input type="file" name="file"/>
</p>
<input type="submit" value="Upload" />
</form>
</body>
</html>
的web.xml:
<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns="http://xmlns.jcp.org/xml/ns/javaee"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee
http://xmlns.jcp.org/xml/ns/javaee/web-app_3_1.xsd"
version="3.1">
<display-name>Portabilidade</display-name>
<!-- location of log4j config file -->
<session-config>
<session-timeout>120</session-timeout>
</session-config>
<context-param>
<param-name>javax.faces.PROJECT_STAGE</param-name>
<param-value>Development</param-value>
</context-param>
<context-param>
<param-name>log4jConfigLocation</param-name>
<param-value>/WEB-INF/classes/log4j.properties</param-value>
</context-param>
<servlet>
<servlet-name>Faces Servlet</servlet-name>
<servlet-class>javax.faces.webapp.FacesServlet</servlet-class>
<load-on-startup>1</load-on-startup>
</servlet>
<servlet-mapping>
<servlet-name>Faces Servlet</servlet-name>
<url-pattern>*.xhtml</url-pattern>
</servlet-mapping>
</web-app>
我已经不知道如何解决这个问题......