2015-08-21 61 views
0

我已经在Jersey中编写了一个Rest服务来上传多个文件。如下所示。但是我想要Restservice类中的属性名称,即name =“metadata”和name =“file”。Jersey FormData,上传多个文件数据

 Select XML file 1: <input type="file" **name="metadata"** size="45" accept=".xml" /> 


     Select PDF file 2: <input type="file" **name="fileak**" size="45" accept=".pdf" /> 

选择XML文件1:

选择PDF文件2:

@POST 
    @Path("/upload") 
    @Consumes(MediaType.MULTIPART_FORM_DATA) 
    @Produces(MediaType.APPLICATION_JSON) 
    public Response uploadFile(
      @FormDataParam("file") List<FormDataBodyPart> parts) { 
     for (FormDataBodyPart part : parts) { 
      FormDataContentDisposition disp = part 
        .getFormDataContentDisposition(); 
      InputStream in = part.getValueAs(InputStream.class); 
     } 

     return Response.ok(" uploaded successfully !!").build(); 
    } 

FormDataContentDisposition仅从表单中抽取内容类型,文件名,而不是输入类型name =“”属性。

任何帮助将不胜感激。

我使用HTML发布请求,如下所示。

发布HTML文件。

<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en" lang="en"> 
    <head> 
     <meta content="text/html;charset=utf-8" http-equiv="Content-Type" /> 
     <meta content="utf-8" http-equiv="encoding" /> 

     <script src="https://ajax.googleapis.com/ajax/libs/jquery/1.11.3/jquery.min.js"></script> 
     <script type="text/javascript"> 

     $(document).ready(function() 
     { 
      $("#uploadBtn").click(function() 
      { 
       $('input[type="file"]').each(function(index, value) 
       { 


        var nameValue=value.attributes[0].value; 
        var file = value.files[0]; 

        if(file) 
        { 
         var formData = new FormData(); 

         formData.append('file', file); 
         //formData["name"] = nameValue; 

         $.ajax({ 
          url : '/publicationservice-web/v1/publication/upload', 
          type : 'POST', 
          data : formData, 
          cache : false, 
          contentType : false, 
          processData : false, 
          name:nameValue, 
          success : function(data, textStatus, jqXHR) { 
           var message = jqXHR.responseText; 
           $("#messages").append("<li>" + message + "</li>"); 
          }, 
          error : function(jqXHR, textStatus, errorThrown) { 
           $("#messages").append("<li style='color: red;'>" + textStatus + "</li>"); 
          } 
         }); 
        } 
       }); 
      }); 
     }); 
     </script> 
</head> 
<body> 
    <h1>NGBulletin Upload System - Metadata and PDF</h1> 

    <form action="v1/publication/upload" method="post" enctype="multipart/form-data"> 

     <p> 
      Select XML file 1: <input type="file" name="metadata" id="metadata" size="45" accept=".xml" /> 
     </p> 
     <p> 
      Select PDF file 2: <input type="file" name="fileak" id="fileak" size="45" accept=".pdf" /> 
     </p> 

     <p> 
      <input id="uploadBtn" type="button" value="Upload PFD Files" /> 
     </p> 

    </form> 

    <ul id="messages"> 
    </ul> 

</body> 
</html> 

回答

3

的事情是,在@FormDataParam("file")价值名称。当你想要通过名称提取所有部分时,可以使用它。例如,你可以有

post(@FormDataParam("metadata") InputStream metaIn, 
    @FormDataParam("metadata") FormDataContentDisposition metaFcd, 
    @FormDataParam("fileak") InputStream fileakIn, 
    @FormDataParam("fileak") FormDataContentDisposition fileakFcd) { 
} 

但是,如果你想通过所有的部分你自己迭代,你应该使用FormDataMultiPart而不是List<FormDataBodyPart>。您可以获取地图,并将其作为关键字。此外,该名称在FormDataBodyPart.getName()中提供。例如

@POST 
@Consumes(MediaType.MULTIPART_FORM_DATA) 
public Response uploadAsset(FormDataMultiPart multipart) { 

    Map<String, List<FormDataBodyPart>> map = multipart.getFields(); 

    for (Map.Entry<String, List<FormDataBodyPart>> entry : map.entrySet()) { 

     for (FormDataBodyPart part : entry.getValue()) { 
      InputStream in = part.getEntityAs(InputStream.class); 
      String name = part.getName(); 
      System.out.println("--- name: " + name); 
     } 
    } 
    return Response.ok("cool upload").build(); 
} 

的一点是,这是很没有意义的尝试,并取得名称(编程),如果你要使用@FormDataParam annatotion,因为你最终已经硬编码的名称(在标注值) ,所以你已经知道了。

+0

嗨PeesKilet ..我也加了我的HTML,你可以请看看....似乎代码只是返回我的“文件”和“文件”,而不是名称属性即元数据和fileak – user3211037

+0

你需要将它们附加为部分。您只添加一个部分(“文件”部分)。 “元数据”和“fileak”应该是不同的部分。 –

+0

或者实际上,再次查看,您正在通过所有类型的文件迭代('$('input [type =“file”]')。each)'并为每个字段分别发出ajax请求。您可能应该将它们合并为一个请求 –