2011-09-16 20 views
7

を返します。のHttpServletRequest#getParts()私は、次のHTMLフォーム持って空のリスト

<form enctype="multipart/form-data" method="post" action="/myservlet"> 
    <input type="file" name="mptest"> 
    <br /> 
    <input type="submit" value="upload"> 
</form> 

をそして私は私がthis answerに基づいて作成次のサーブレットがあります。

package com.functions; 

import java.io.*; 
// import java.sql.Connection; 
// import java.sql.PreparedStatement; 
// import java.sql.ResultSet; 
// import javax.servlet.RequestDispatcher; 
import javax.servlet.ServletException; 
import javax.servlet.http.HttpServlet; 
import javax.servlet.http.HttpServletRequest; 
import javax.servlet.http.HttpServletResponse; 
import javax.servlet.http.Part; 

// import com.functions.utility.DBConnector; 
public class restore extends HttpServlet { 

    private static final long serialVersionUID = 8097085789553030042L; 

    protected void doPost(HttpServletRequest request, 
      HttpServletResponse response) throws ServletException, IOException { 
     System.out.println("--------------------"); 
     System.out.println(" On restore.java "); 
     System.out.println("--------------------"); 
     try { 
      fetchDataFromDB(request, response); 
     } catch (InterruptedException e) { 
      // TODO Auto-generated catch block 
      e.printStackTrace(); 
     } 
    } 

    private void fetchDataFromDB(HttpServletRequest request, 
      HttpServletResponse response) throws InterruptedException, 
      IllegalStateException, ServletException { 
     try { 
      System.out.println("Test 1"); 
      for (Part part : request.getParts()) { 
       String filename = getFilename(part); 
       System.out.println("Test 2"); 
       if (filename == null) { 
        System.out.println("Test 3"); 
        // Process regular form field (input 
        // type="text|radio|checkbox|etc", select, etc). 
        String fieldname = part.getName(); 
        System.out.println(fieldname); 
        String fieldvalue = getValue(part); 
        System.out.println(fieldvalue); 
        // ... (do your job here) 
       } else if (!filename.isEmpty()) { 
        System.out.println("Test 4"); 
        // Process form file field (input type="file"). 
        String fieldname = part.getName(); 
        System.out.println(fieldname); 
        filename = filename 
          .substring(filename.lastIndexOf('/') + 1) 
          .substring(filename.lastIndexOf('\\') + 1); // MSIE 
                     // fix. 
        InputStream filecontent = part.getInputStream(); 
        System.out.println(filecontent); 
        String[] command = new String[] { 
          "C:/Program Files (x86)/MySQL/MySQL Server " 
          + "5.5/bin/mysql", 
          "--user=root", "--password=root", "dummy", "-e", 
          "source "+"C:/Users/John/Desktop/LMS/backup.sql" }; 
        Process restore = Runtime.getRuntime().exec(command); 
        int check = restore.waitFor(); 
        System.out.println(check); 
       } 
      } 
     } catch (IOException ex) { 
      ex.printStackTrace(); 
     } 
    } 

    private static String getFilename(Part part) { 
     for (String cd : part.getHeader("content-disposition").split(";")) { 
      if (cd.trim().startsWith("filename")) { 
       return cd.substring(cd.indexOf('=') + 1).trim() 
         .replace("\"", ""); 
      } 
     } 
     return null; 
    } 

    private static String getValue(Part part) throws IOException { 
     BufferedReader reader = new BufferedReader(new InputStreamReader(
       part.getInputStream(), "UTF-8")); 
     StringBuilder value = new StringBuilder(); 
     char[] buffer = new char[1024]; 
     for (int length = 0; (length = reader.read(buffer)) > 0;) { 
      value.append(buffer, 0, length); 
     } 
     return value.toString(); 
    } 
} 

しかしためのループをrequest.getParts()には入力されません。これはどのようにして起こり、どのように解決できますか?

+0

可能重複[JSP /サーブレットにファイルをアップロードするには?](http://stackoverflow.com/questions/2422468/how-to-upload-files-in-jsp-servlet/2424824#2424824 ) – BalusC

+0

リンク先の質問への私の答えは、JSP/Servletでアップロードされたファイルを処理する方法について、リンクの下にいくつかのリンクがあります。 – BalusC

+0

私はあなたがリンクで行った提案を試しました....でもforループを入力することはありません..... – John

答えて

17

サーブレット3.0 HttpServletRequest#getParts()を使用する場合は、サーブレットに@MultipartConfigという注釈を付ける必要があります。

@WebServlet(urlPatterns={"/myservlet"}) 
@MultipartConfig 
public class Myservlet extends HttpServlet { 

    // ... 
} 
+0

はまだC:/ Users/John/Desktop/LMS/backupではなくbackup.sqlを与えます。 sql – John

+3

なぜ地球上でフルパスが必要ですか? http://stackoverflow.com/questions/81180/how-to-get-the-file-path-from-html-input-form-in-firefox-3/3374408#3374408ファイルコンテンツを取得して保存するだけですサーバーのディスクに保存し、保存したファイルのパスでコマンドを呼び出します。 – BalusC

+0

「@ MultipartConfig」という注釈を追加しても私の場合は役に立たなかった(Tomcat 7.0.70 with Servlet 3.0) – basZero

関連する問題