Подтвердить что ты не робот

Org.springframework.web.multipart.MultipartException: текущий запрос не является множественным запросом

Я пытаюсь отправить многостраничный запрос на сервер, но я получаю следующее исключение  Состояние HTTP 500 - обработка запроса не выполнена; Вложенное исключение - org.springframework.web.multipart.MultipartException: текущий запрос не является множественным запросом

<div id="myModal" class="modal hide fade" tabindex="-1" role="dialog" aria-labelledby="myModalLabel" aria-hidden="true">
    <div class="modal-body">
        <form id="imageuploadForm" action="<c:url value="/members/profileimageupload" />" method="POST" enctype="multipart/form-data">
            <div style="width:40%; float:left">
                <div class="fileupload fileupload-new" data-provides="fileupload">
                    <div class="fileupload-preview thumbnail" style="width: 200px; height: 150px;"></div>
                    <div>
                        <span class="btn btn-file">
                            <span class="fileupload-new">Select image</span>
                            <span class="fileupload-exists">Change</span>
                            <input id="imageFile" name="imageFile" type="file" />
                        </span>
                        <a href="#" class="btn fileupload-exists" data-dismiss="fileupload">Remove</a>
                    </div>
                </div>
            </div>
            <div style="width:40%; float:right" >
                <div class="progress">
                    <div class="bar" style="width: 60%;"></div>
                </div>
            </div>
        </form>
    </div>
    <div class="modal-footer">
       <button class="btn btn-success" id="submit">Upload</button>
       <button class="btn btn-primary" data-dismiss="modal" aria-hidden="true" >Close</button>
    </div>
 </div>

мой вызов ajax, который отправляет запрос.

$(function() {
    //twitter bootstrap script
    $("button#submit").click(function(){
        var $form = $("#imageuploadForm");
        var type = $form.attr('method');
        var url =  $form.attr('action');
        $.ajax({
            type: $form.attr('method'),
            url: $form.attr('action'),
            data: $form.serialize(),

            success: function(msg){
                $("#form-content").modal('hide');
            },

            error: function(){
            }
        });
    });
});

мой контроллер, который должен обрабатывать запрос

@RequestMapping(value="/profileimageupload",method= RequestMethod.POST)
    public void uploadProfileImage(@RequestParam(value="imageFile") final MultipartFile file) throws NumberFormatException, IOException{
    ////
}            

У меня была следующая веб-конфигурация для многостраничного файла

@Configuration
@EnableWebMvc
public class WebConfig extends WebMvcConfigurerAdapter {

    /**
    * Supports FileUploads.
    */
    @Bean
    public MultipartResolver multipartResolver() {
        CommonsMultipartResolver multipartResolver = new CommonsMultipartResolver();
        multipartResolver.setMaxUploadSize(500000000);
        return multipartResolver;
    }
}
4b9b3361

Ответ 1

Проверьте, добавили ли вы CommonsMultipartResolver в Spring -Servlet.xml.

    <bean id="multipartResolver" class="org.springframework.web.multipart.commons.CommonsMultipartResolver"/>

Тогда, добавьте enctype в multipart/form-data в вашей форме

<form id="fileupload" method="post" enctype="multipart/form-data">

Наконец, в контроллере,  Request > MultipartHttpServletRequest

 @RequestMapping(value = "/profileimageupload", method = RequestMethod.POST)
public ModelAndView uploadProfileImage(MultipartHttpServletRequest request) {}

Зависимости

  • Обще-fileupload.jar
  • Обще-io.jar

Ответ 2

Повторите попытку с помощью < заголовков ":

@RequestMapping(value = "/profileimageupload", headers = "content-type=multipart/*", method = RequestMethod.POST)

и вызов ajax: Как я могу загружать файлы асинхронно?

Я надеюсь, что это вам поможет!

Ответ 3

Кажется, что ваша форма тега не очень хорошо сформирована и все, что есть после

'action="<c:url value="/members/profileimageupload" />"' 

игнорируется. Попробуйте написать вот так и посмотрите, работает ли это:

action="<c:url value='/members/profileimageupload' />"