Member 14639038 Ответов: 2

Сервлет Fileupload, показывающий исключение nullpointer


уважаемый господин,

Я написал бизнес логику в сервлете :
  1  package com.rfmsSite.upload;
  2  
  3  import java.io.FileNotFoundException;
  4  import java.io.IOException;
  5  import java.io.InputStream;
  6  import java.io.PrintWriter;
  7  import java.sql.Connection;
  8  import java.sql.PreparedStatement;
  9  import java.sql.SQLException;
 10  import java.sql.Statement;
 11  
 12  import javax.servlet.ServletException;
 13  import javax.servlet.annotation.MultipartConfig;
 14  import javax.servlet.annotation.WebServlet;
 15  import javax.servlet.http.HttpServlet;
 16  import javax.servlet.http.HttpServletRequest;
 17  import javax.servlet.http.HttpServletResponse;
 18  import javax.servlet.http.Part;
 19  
 20  import org.apache.coyote.http11.InputFilter;
 21  
 22  import com.rfmsSite.util.DBhelper;
 23  
 24  @WebServlet("/uploadBlob")
 25  @MultipartConfig
 26  public class UploadServlet extends HttpServlet{
 27  	public static Part filepart=null;
 28  	public static Connection conn =null;
 29  	public static PreparedStatement stmt = null;
 30  	public static final String upload_xls = "insert into attachment values(?);";
 31  	@Override
 32  	protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
 33  		// TODO Auto-generated method stub
 34  		PrintWriter out = resp.getWriter();
 35  		resp.setContentType("text/html");
 36  		
 37  		filepart = req.getPart("Upload file");
 38  		InputStream excl_bytes = null;
 39  		try
 40  		{
 41  		  if(!filepart.getContentType().equals("application/vnd.ms-excel")) //line 41
 42  		  {
 43  			out.println("<br> invalid file format");  
 44  			return;
 45  		  }
 46  		  else if(filepart.getSize()>10240000)
 47  		  {
 48  			  out.println("<br> File size too big");
 49                return;
 50  		  }
 51  		  
 52  		  excl_bytes = filepart.getInputStream();
 53  		  final byte[] bytes = new byte[excl_bytes.available()];
 54  		  excl_bytes.read(bytes);
 55  		  try
 56  		  {
 57  			  conn = DBhelper.createConnection();
 58  			  int success=0;
 59  			  stmt = conn.prepareStatement(upload_xls);
 60  			  stmt.setBytes(2, bytes);
 61  			  success = stmt.executeUpdate();
 62  			  if(success>=1)
 63  			  {
 64  				  out.println("br>File successfully stored");
 65  			  }
 66  		  }
 67  			  catch (SQLException e) {
 68  			  out.println(e);
 69  			  System.exit(0);
 70  		  }
 71  			// TODO: handle exception
 72  		  }
 73  		  
 74  		  finally
 75  		  {
 76  			  if(excl_bytes!=null)
 77  			  {
 78  				  excl_bytes.close();
 79  			  }
 80  			  
 81  			  if(out!=null)
 82  			  {
 83  				  out.close();
 84  			  }
 85  		  }
 86  	}
 87  }

Вот:
код страницы jsp:
<%@ page language="java" contentType="text/html; charset=ISO-8859-1" pageEncoding="ISO-8859-1"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
    <meta http-equiv="Content-Type" content="text/html; charset=ISO-8859-1">
    <title>File Upload</title>
</head>
<body>
    <a href="Home.html">Home</a>
    <a href="ExcelServlet">Excel data</a>
    <hr>
    <form action="uploadBlob" method="post" enctype="multipart/form-data">
        <table>
        <tr>
            <td><input type="file" name="file1"><td>
        </tr>
        <tr><td colspan="2">
            <input type="submit" value="Upload file" name="upload"/>
       </table>
    </form>
</body>
</html>

когда я запускаю это приложение , то возникает это исключение:
application/application/vnd.openxmlformats-officedocument.spreadsheetml.sheet


Что я уже пробовал:

if(!filepart.getContentType().equals("application/application/vnd.openxmlformats-officedocument.spreadsheetml.sheet"))

ZurdoDev

Что-то есть нуль. Все, что вам нужно сделать, это отладить его и найти, какая строка кода вызывает ошибку, а что в этой строке равно нулю. Затем выясните, как это исправить.

2 Ответов

Рейтинг:
14

OriginalGriff

Это одна из самых распространенных проблем, которые нам задают, и это также та, на которую мы меньше всего готовы ответить, но вы больше всего готовы ответить сами.

Позвольте мне просто объяснить, что означает ошибка: вы пытались использовать переменную, свойство или возвращаемое значение метода, но оно содержит null - что означает, что в переменной нет экземпляра класса.
Это немного похоже на карман: у вас есть карман в рубашке, который вы используете, чтобы держать ручку. Если вы сунете руку в карман и обнаружите, что там нет ручки, вы не сможете подписать свое имя на листе бумаги - и вы получите очень смешные взгляды, если попытаетесь! Пустой карман дает вам нулевое значение (здесь нет ручки!), поэтому вы не можете сделать ничего, что обычно делали бы, когда вы извлекли свою ручку. Почему он пуст? Вот в чем вопрос - может быть, вы забыли взять ручку, когда уходили из дома сегодня утром, или, возможно, вы оставили ручку в кармане вчерашней рубашки, когда снимали ее вчера вечером.

Мы не можем сказать, потому что нас там не было, и, что еще важнее, мы даже не можем видеть вашу рубашку, не говоря уже о том, что находится в кармане!

Вернемся к компьютерам, и вы каким - то образом сделали то же самое-и мы не можем увидеть ваш код, а тем более запустить его и узнать, что содержит null, когда это не должно быть.
Но вы можете - и Visual Studio поможет вам здесь. Запустите свою программу в отладчике, и когда она выйдет из строя, VS покажет вам строку, в которой она обнаружила проблему. Затем вы можете начать просматривать различные его части, чтобы увидеть, какое значение равно null, и начать просматривать свой код, чтобы узнать, почему. Поэтому поставьте точку останова в начале метода, содержащего строку ошибки, и снова запустите программу с самого начала. На этот раз VS остановится перед ошибкой и позволит вам изучить, что происходит, пройдя через код, глядя на ваши значения.

Но мы не можем этого сделать - у нас нет вашего кода, мы не знаем, как его использовать, если бы он у нас был, у нас нет ваших данных. Так что попробуйте - и посмотрите, сколько информации вы можете узнать!


Member 14639038

я знаю, что это связано с расширением mime

Рейтинг:
12

Richard Deeming

Ты звонишь req.getPart("Upload file");, но ваш <input> имеет name="file1".

Я подозреваю, что это имя перешло к getPart необходимо соответствовать name атрибут на экране <input>:

filepart = req.getPart("file1");
Кроме того, ваш альтернативный тип MIME неверен - у вас не будет двух application/ префиксы.
if(!filepart.getContentType().equals("application/vnd.openxmlformats-officedocument.spreadsheetml.sheet"))


Member 14639038

какой будет тип MIME для Excel с помощью .и того же формата .XLS, так как

Member 14639038

я не имею об этом ни малейшего представления

Member 14639038

"application/vnd.openxmlformats-officedocument.spreadsheetml.sheet" этот тип mime не работает как для .xls, так и для .xlsx

Richard Deeming

Тип пантомимы для .xlsx является application/vnd.openxmlformats-officedocument.spreadsheetml.sheet.

Тип пантомимы для .xls является application/vnd.ms-excel.

Вам нужно будет проверить оба типа файлов; нет никакой волшебной строки, которая соответствовала бы обоим типам файлов.

Member 14639038

кей ! - сэр ! я попробую это сделать .
но я хочу, чтобы оба формата были приняты.
БТ как я могу это сделать

Richard Deeming

Тогда вам нужно будет проверить и то, и другое.