我写这个是为了在指定的文件夹中上传图片并将路径存储在数据库中,但是当我点击添加时会显示一个空白页面,我已经在<...中创建了所有文件夹strong> webcontent 。我正在使用tomcat服务器:
我的 upload.jsp 代码如下所示:
<form action="Add" method=post enctype="multipart/form-data">
<p>Book name: <input type="text" name="bname" required/></p>
<p>Price:<input type="text" name="bprice" required/></p>
<p>Quantity:<input type="text" name="bqty" required/></p>
<p>Image: <input type="file" name="file" required/></p>
<p>Course: <select name="course">
<option>course 1</option>
<option>course 2</option> <!-- Some more options-->
<input type="submit" value="Add" name="Submit"/></p>
</form>
Add.java servlet代码为:
protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
response.setContentType("text/html");
PrintWriter out=response.getWriter();
String bname=request.getParameter("bname");
String bprice=request.getParameter("bprice");
String bqty=request.getParameter("bqty");
String path="images";
String file=request.getParameter("file");
String course=request.getParameter("course");
if(course.equals("course 1"))
{
path="images/folder1";
}
else if(course.equals("course 2"))
{
path="images/folder2";
}
else
{
path="images";
}
MultipartRequest m=new MultipartRequest(request,path);
try
{
Class.forName("com.mysql.jdbc.Driver");
Connection con=DriverManager.getConnection("",user,pass);
PreparedStatement ps=con.prepareStatement("insert into product(bname,course,price,qty,path) values (?,?,?,?,?)");
ps.setString(1,bname);
ps.setString(2,course);
ps.setString(3,bprice);
ps.setString(4,bqty);
ps.setString(5,path+file);
ps.executeUpdate();
}
catch(Exception e)
{
e.printStackTrace();
}
out.print("<p>Product added!</p>");
RequestDispatcher rd=request.getRequestDispatcher("upload.jsp");
rd.include(request, response);
}
我得到NullPointer异常。 我在某处读到了而不是使用 用request.getParameter() 我应该使用 m.getParameter()
我做到了并且有效,但是这不能解决我的问题,因为我的代码根据表单中 course 的值来确定路径。
而且我还需要上传文件的文件名,现在我这样做: String file = request.getParameter(&#34; file&#34;);
我正在尝试一些示例代码,当我使用m.getParameter()时,我设法获取除文件之外的所有字段的值(我希望那个因为我想将img路径存储在数据库中)。 当我不使用enctype = multipart / form-data时,一切正常(我也得到文件名),除了内容是多部分的错误(我知道这很明显)。
答案 0 :(得分:2)
您可以使用cos-multipart.jar
同时获取表单字段和文件。
以下对我有用:
public class FileUploadHandler extends HttpServlet {
private final String UPLOAD_DIRECTORY = "/home/mario/Downloads";
@Override
protected void doPost(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
//fix max file size 500 Mb
int maxFileSize = 500000 * 1024;
int maxMemSize = maxFileSize;
//getting form fields (both text as well as file) (enctype=multipart/form-data)
MultipartRequest mreq = new MultipartRequest(request, UPLOAD_DIRECTORY, maxFileSize);
String uname = mreq.getParameter("username"); //give 'id' in html accordingly
String dateofupload = mreq.getParameter("uploaddate");
//System.out.println(uname);
String NEW_UPLOAD_DIRECTORY = UPLOAD_DIRECTORY;
//get actual file name here //name field in html tag has to be given accordingly
String uploadedfilename = mreq.getFilesystemName("file");
//renaming & moving the file to new location
File newfileloc = new File(NEW_UPLOAD_DIRECTORY + "/" + uploadedfilename);
Boolean uploadresult = mreq.getFile("file").renameTo(newfileloc); //true if success
}
}
这最初将文件保存到某个位置并重命名/移动到新位置。我本可以将它保存在所需的位置,但为了做到这一点,我需要文件名,只有servlet请求。但要访问filename
,我们需要创建“Multipart”请求对象。我试图创建two
这样的东西,一个用于访问字段,另一个用于保存文件。但是,cos-multipart.jar在处理这个问题上有一些缺陷。
答案 1 :(得分:1)
ServletRequest#getParameter
仅适用于application/x-www-form-urlencoded
数据(如果您未在表单上指定enctype
属性,则默认使用此编码)。您可以阅读有关表单内容类型here的更多信息。
从第
行开始MultipartRequest m=new MultipartRequest(request,path);
我假设您使用的是com.oreilly.servlet library。
在这种情况下,使用MultipartRequest#getParameter
是获取字段值的正确方法。要获取上传文件的名称,您可以使用MultipartRequest#getFilesystemName
。
我的代码根据表单
中的课程值确定路径
我担心您无法使用com.oreilly.servlet库以明确的方式执行此操作。你能做的就是像这样自己移动文件:
m.getFile("file").renameTo(new File("newPath"));
或者,您可以考虑使用其他库来处理多部分数据,例如Apache Commons FileUpload。
答案 2 :(得分:0)
您可能需要考虑使用Apache commons FileUpload。它可以帮助您处理这些场景并为您处理大多数业务逻辑。
使用Apache Commons FileUpload时,您可以像这样解析请求:
// Create a factory for disk-based file items
DiskFileItemFactory factory = new DiskFileItemFactory();
// Configure a repository (to ensure a secure temp location is used)
ServletContext servletContext = this.getServletConfig().getServletContext();
File repository = (File) servletContext.getAttribute("javax.servlet.context.tempdir");
factory.setRepository(repository);
// Create a new file upload handler
ServletFileUpload upload = new ServletFileUpload(factory);
// Parse the request
List<FileItem> items = upload.parseRequest(request);
您可以解析所有个人
// Process the uploaded items
Iterator<FileItem> iter = items.iterator();
while (iter.hasNext()) {
FileItem item = iter.next();
if (item.isFormField()) {
processFormField(item);
} else {
processUploadedFile(item);
}
}
答案 3 :(得分:0)
try this way:
DiskFileItemFactory factory = new DiskFileItemFactory();
factory.setSizeThreshold(MEMORY_THRESHOLD);
factory.setRepository(new File(System.getProperty("java.io.tmpdir")));
ServletFileUpload upload = new ServletFileUpload(factory);
upload.setFileSizeMax(MAX_FILE_SIZE);
upload.setSizeMax(MAX_REQUEST_SIZE); // sets maximum size of request (include file + form data)
String uploadPath = getServletContext().getRealPath("") + File.separator + UPLOAD_DIRECTORY;
File uploadDir = new File(uploadPath);
if (!uploadDir.exists()) {
uploadDir.mkdir();
}
List<FileItem> formItems = upload.parseRequest(request);
if (formItems != null && formItems.size() > 0) {
for (FileItem item : formItems) {
if (!item.isFormField()) {
//file field
} else {
other form field
}