Проблема с multipart / form-data - PullRequest
       7

Проблема с multipart / form-data

2 голосов
/ 09 октября 2009

Я не могу получить значения как из файлов, так и из текстового ввода в сервлете, когда моя форма содержит данные multipart / form-data Я использую apache.commons.fileuploads для помощи с загрузками. Какие-либо предложения. Также в приведенном ниже коде есть некоторые вещи, которые я считаю более эффективными. Есть ли лучший способ хранить эти несколько файлов в БД.

public void performTask(javax.servlet.http.HttpServletRequest request, javax.servlet.http.HttpServletResponse response)
    {
        boolean promo = false;
        Database db = new Database();
        Homepage hp = db.getHomePageContents();

        String part = ParamUtils.getStringParameter(request, "part", "");
        if(part.equals("verbage"))
        {
            String txtcontent = (String)request.getParameter("txtcontent");
            String promoheader = (String)request.getParameter("promoheader");
            String promosubheader = (String)request.getParameter("promosubheader");
            hp.setBodyText(txtcontent);
            hp.setPromoHeader(promoheader);
            hp.setPromoSubHeader(promosubheader);
            System.err.println(txtcontent);
        }
        else
        {

            boolean isMultipart = ServletFileUpload.isMultipartContent(request);
            if (!isMultipart) 
            {

            }
            else {
                FileItemFactory factory = new DiskFileItemFactory();
                ServletFileUpload upload = new ServletFileUpload(factory);
                List items = null;
                try {
                items = upload.parseRequest(request);
                //System.err.print(items);
                } catch (FileUploadException e) {
                e.printStackTrace();
                }

                Iterator itr = items.iterator();
                while (itr.hasNext()) {
                    FileItem item = (FileItem) itr.next();
                    if(item.getFieldName().equals("mainimg1"))
                    {
                        if(item.getName() !="") hp.setMainImg1(item.getName());
                    }
                    if(item.getFieldName().equals("mainimg2"))
                    {
                        if(item.getName() !="") hp.setMainImg2(item.getName());
                    }
                    if(item.getFieldName().equals("mainimg3"))
                    {
                        if(item.getName() !="") hp.setMainImg3(item.getName());
                    }
                    if(item.getFieldName().equals("promoimg1"))
                    {
                        promo = true;
                        if(item.getName() !="")
                        {
                            hp.setPromoImg1(item.getName());
                            try {
                                File savedFile = new File("/Library/resin-4.0.1/webapps/ROOT/images/promoImg1.jpg");
                                item.write(savedFile);
                                //System.err.print(items);
                            } catch (Exception e) {
                                    System.err.println(e.getMessage());
                            }
                        }
                    }
                    if(item.getFieldName().equals("promoimg2"))
                    {
                        if(item.getName() !="") 
                        {
                            hp.setPromoImg2(item.getName());
                            try {
                                File savedFile = new File("/Library/resin-4.0.1/webapps/ROOT/images/promoImg2.jpg");
                                item.write(savedFile);
                                //System.err.print(items);
                            } catch (Exception e) {
                                    System.err.println(e.getMessage());
                            }
                        }
                    }
                    if(item.getFieldName().equals("promoimg3"))
                    {
                        if(item.getName() !="")
                        {
                            hp.setPromoImg3(item.getName());
                            try {
                                File savedFile = new File("/Library/resin-4.0.1/webapps/ROOT/images/promoImg3.jpg");
                                item.write(savedFile);
                                //System.err.print(items);
                            } catch (Exception e) {
                                    System.err.println(e.getMessage());
                            }
                        }
                    }


                    System.err.println("FNAME =" + item.getFieldName() + " : " + item.getName());
                    if (item.isFormField()) {
                    } 
                    else {
                        try {
                            if(!promo)
                            {
                                String itemName = item.getName();
                                File savedFile = new File("/Library/resin-4.0.1/webapps/ROOT/images/"+itemName);
                                item.write(savedFile);
                            }
                            //System.err.print(items);
                        } catch (Exception e) {
                                System.err.println(e.getMessage());
                          }
                    }
                }
            }
        }


        db.updateHomePageContent(hp);

Ответы [ 2 ]

10 голосов
/ 10 июня 2010

При использовании multipart/form-data обычными значениями поля ввода являются , а не , доступные для request.getParameter(), поскольку стандартный Servlet API до версии 3.0 не имеет встроенных средств для их анализа. Именно поэтому существует Apache Commons FileUpload. Вам нужно проверить, возвращает ли FileItem#isFormField() true, а затем собрать их из FileItem.

Прямо сейчас вы игнорируете эти значения в коде. Следует признать, что FileItem - это вводящее в заблуждение имя, если бы это был я, я бы назвал его MultipartItem или просто Part, представляющий часть тела multipart/form-data, которое содержит как загруженные поля, так и нормальные параметры.

Вот начальный пример того, как вы должны правильно проанализировать multipart/form-data запрос:

List<FileItem> items = new ServletFileUpload(new DiskFileItemFactory()).parseRequest(request);
for (FileItem item : items) {
    if (item.isFormField()) {
        // Process normal fields here.
        System.out.println("Field name: " + item.getFieldName());
        System.out.println("Field value: " + item.getString());
    } else {
        // Process <input type="file"> here.
        System.out.println("Field name: " + item.getFieldName());
        System.out.println("Field value (file name): " + item.getName());
    }            
}

Обратите внимание, что вы также упустили из виду неправильное поведение MSIE, так как оно отправляет полный клиентский путь вдоль имени файла. Вы хотите удалить его из item.getName() согласно FileUpload FAQ :

String fileName = item.getName();
if (fileName != null) {
    filename = FilenameUtils.getName(filename);
}
0 голосов
/ 09 октября 2009

У меня были подобные проблемы в прошлом. Единственный способ, которым я смог найти решение проблемы, - это загрузить файл в его собственную форму.

...