SpringMVC中使用CommonsMultipartResolver进行文件上传

概述:

CommonsMultipartResolver是基于Apache的Commons FileUpload来实现文件上传功能的。所以在项目中需要相应的jar文件。

FileUpload版本要求1.2及以上。相应的gradle配置:

"commons-fileupload:commons-fileupload:1.2.2"

上传方法的实现

1. 代码方式

直接在controler中new一个CommonsMultipartResolver。

@Controller
@RequestMapping(value = "/file")
public class FileController {

    @RequestMapping(value = "/commUploadA")
    @ResponseBody
    public JSONObject commUploadA(HttpServletRequest request) {
        JSONObject json = new JSONObject();
        json.put("succ", false);
        try {
            //直接new一个CommonsMultipartResolver
            CommonsMultipartResolver cmr = new CommonsMultipartResolver(request.getServletContext());
            cmr.setDefaultEncoding("utf-8");
            cmr.setMaxInMemorySize(40960);
            cmr.setMaxUploadSize(10485760000L);
            if (cmr.isMultipart(request)) {
                MultipartHttpServletRequest multipartRequest = cmr.resolveMultipart(request);
                MultipartFile file = multipartRequest.getFile("uploadFile");// 与页面input的name相同
                File imageFile = new File("d:/upload1.jpg");// 上传后的文件保存目录及名字
                file.transferTo(imageFile);// 将上传文件保存到相应位置
                json.put("succ", true);
                return json;
            }

        } catch (Exception e) {
            e.printStackTrace();
        }
        return json;
    }

}

2. Xml方式

通过spring配置一个名为”multipartResolver”的bean。

<bean id="multipartResolver"
    class="org.springframework.web.multipart.commons.CommonsMultipartResolver">
    <property name="defaultEncoding" value="utf-8"></property>
    <property name="maxUploadSize" value="10485760000"></property>
    <property name="maxInMemorySize" value="40960"></property>
</bean>

controller中的方法做相应修改。

@Controller
@RequestMapping(value = "/file")
public class FileController {

    @RequestMapping(value = "/commUploadB")
    @ResponseBody
    public JSONObject commUploadB(MultipartHttpServletRequest request) {//参数类型不同
        JSONObject json = new JSONObject();
        json.put("succ", false);
        try {
            MultipartFile file = request.getFile("uploadFile");// 与页面input的name相同
            File imageFile = new File("d:/upload2.jpg");// 上传后的文件保存目录及名字
            file.transferTo(imageFile);// 将上传文件保存到相应位置
            json.put("succ", true);
            return json;
        } catch (Exception e) {
            e.printStackTrace();
            return json;
        }
    }
}

两种方法的区别:

  1. 将CommonsMultipartResolver的实例化由代码实现改为了xml配置实现。
  2. 方法中的参数类型由HttpServletRequest变为了MultipartHttpServletRequest。

而上传的获取和保存逻辑没有变化。

注意:

在使用xml方式时,bean的名字必须为:multipartResolver。可在org.springframework.web.servlet.DispatcherServlet中找到原因:

public class DispatcherServlet extends FrameworkServlet {

    /** Well-known name for the MultipartResolver object in the bean factory for this namespace. */
    public static final String MULTIPART_RESOLVER_BEAN_NAME = "multipartResolver";

    ......
    /**
     * Initialize the MultipartResolver used by this class.
     * <p>If no bean is defined with the given name in the BeanFactory for this namespace,
     * no multipart handling is provided.
     */
    private void initMultipartResolver(ApplicationContext context) {
        try {
            this.multipartResolver = context.getBean(MULTIPART_RESOLVER_BEAN_NAME, MultipartResolver.class);
            if (logger.isDebugEnabled()) {
                logger.debug("Using MultipartResolver [" + this.multipartResolver + "]");
            }
        }
        catch (NoSuchBeanDefinitionException ex) {
            // Default is no multipart resolver.
            this.multipartResolver = null;
            if (logger.isDebugEnabled()) {
                logger.debug("Unable to locate MultipartResolver with name '" + MULTIPART_RESOLVER_BEAN_NAME +
                        "': no multipart request handling provided");
            }
        }
    }
    ......
}

简要分析CommonsMultipartResolver

CommonsMultipartResolver实现接口org.springframework.web.multipart.MultipartResolver,主要作用是将HttpSerlvetRequest封装成MultipartHttpServletRequest。

public interface MultipartResolver {
    ......
    MultipartHttpServletRequest resolveMultipart(HttpServletRequest request) throws MultipartException;
    ......
}

具体的封装方法参考CommonsMultipartResolver对resolveMultipart的实现:

org.springframework.web.multipart.commons.CommonsMultipartResolver.resolveMultipart(javax.servlet.http.HttpServletRequest)
  • 5
    点赞
  • 26
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
### 回答1: SpringMVC 是一种基于 Java 语言的 Web 框架,它提供了一种方便的方式来处理 HTTP 请求和响应。使用 SpringMVC 进行文件上传非常简单,以下是基本的步骤: 1. 在 SpringMVC 配置文件启用 multipart 解析器。 2. 创建一个表单,其包含一个文件上传输入框。 3. 创建一个控制器方法,该方法接收上传文件。 4. 在控制器方法处理文件,并进行必要的操作,例如保存文件。 这里是一个简单的示例,演示如何使用 SpringMVC 进行文件上传: 1. 在 SpringMVC 配置文件启用 multipart 解析器。 ``` <bean id="multipartResolver" class="org.springframework.web.multipart.commons.CommonsMultipartResolver"> <!-- 设置最大上传文件大小 --> <property name="maxUploadSize" value="100000" /> </bean> ``` 2. 创建一个表单,其包含一个文件上传输入框。 ``` <form method="POST" action="/upload" enctype="multipart/form-data"> <input type="file" name="file" /> <input type="submit" value="Upload" /> </form> ``` 3. 创建一个控制器方法,该方法接收上传文件。 ``` @Controller public class FileUploadController { @RequestMapping(value = "/upload", method = RequestMethod.POST) public String handleFileUpload(@RequestParam("file") MultipartFile file, Model model) { if (!file.isEmpty()) { try { byte[] bytes = file.getBytes(); // 处理文件,例如保存到服务器或数据库 // ... model.addAttribute("message", "文件上传成功"); } catch (IOException e) { model.addAttribute("message", "文件上传失败"); } } else { model.addAttribute("message", "请选择一个文件上传"); } return "uploadResult"; } } ``` 4. 在控制器方法处理文件,并进行必要的操作,例如保存文件。 上述代码,`@RequestParam("file")` 注解表示要接收名为 `file` 的上传文件,并将其封装为 `MultipartFile` 对象。`Model` 对象用于向视图传递数据,此处使用它来传递文件上传结果的消息。 当用户上传一个文件时,控制器方法将会被调用,`MultipartFile` 对象将包含上传文件的数据。我们可以使用 `getBytes()` 方法来获取文件的字节数组,然后对其进行必要的操作,例如将文件保存到服务器或数据库。最后,我们将上传结果的消息添加到 `Model` 对象,然后返回一个视图来显示结果。 这就是使用 SpringMVC 进行文件上传的基本步骤。需要注意的是,在实际开发,我们可能需要添加一些额外的功能,例如文件大小限制、文件型验证等。 ### 回答2: SpringMVC基于注解使用文件上传需要完成以下几个步骤。 首先,需要在Spring配置文件配置MultipartResolver,以便Spring能够处理文件上传。 在配置文件添加如下代码: ```xml <bean id="multipartResolver" class="org.springframework.web.multipart.commons.CommonsMultipartResolver"> <!-- 设置上传文件的最大大小 --> <property name="maxUploadSize" value="5242880"/> </bean> ``` 然后,在控制器添加处理文件上传的方法,并使用@RequestParam注解来接收上传文件。 ```java @Controller public class FileUploadController { @RequestMapping(value = "/upload", method = RequestMethod.POST) public String handleFileUpload(@RequestParam("file") MultipartFile file) { if (!file.isEmpty()) { try { // 获取文件内容并进行处理 byte[] bytes = file.getBytes(); // 文件处理逻辑... return "上传成功"; } catch (IOException e) { e.printStackTrace(); return "上传失败"; } } else { return "上传失败,文件为空"; } } } ``` 在这个例子,我们使用了@RequestParam注解来获取上传文件,其file是表单文件输入框的name属性。handleFileUpload方法,我们将接收到的文件内容转为字节数组,并进行相关处理。 最后,在前端页面添加文件上传表单。可以使用普通的HTML表单或者使用Spring的form标签。例如: ```html <form action="/upload" method="post" enctype="multipart/form-data"> <input type="file" name="file" /> <input type="submit" value="上传" /> </form> ``` 通过以上步骤,就可以在SpringMVC基于注解实现文件上传功能了。有了MultipartResolver的配置和上传文件的处理方法,用户可以通过上传文件的表单将文件发送到服务器,并在处理方法进行相关的文件处理操作。 ### 回答3: 在Spring MVC,我们可以使用注解来实现文件上传。首先,我们需要在spring配置文件启用MultipartResolver,以便处理文件上传。 接下来,在我们的控制器,我们可以使用@RequestParam注解来接收文件上传。 例如,我们可以编写一个处理文件上传的控制器方法: ```java @RequestMapping(value = "/upload", method = RequestMethod.POST) public String handleFileUpload(@RequestParam("file") MultipartFile file) { // 处理文件上传逻辑 if (!file.isEmpty()) { try { byte[] bytes = file.getBytes(); // 保存文件到指定路径 File serverFile = new File("path/to/save/file"); BufferedOutputStream stream = new BufferedOutputStream(new FileOutputStream(serverFile)); stream.write(bytes); stream.close(); return "文件上传成功"; } catch (IOException e) { e.printStackTrace(); return "文件上传失败"; } } else { return "请选择一个文件进行上传"; } } ``` 在上述示例,我们使用@RequestParam注解来指定上传文件参数名为"file",并将其型设置为MultipartFile。通过调用getByes()方法来获取文件的字节数据,并将数据保存到服务器文件路径下的serverFile文件。 需要注意的是,为了确保文件上传成功,我们需要配置正确的文件保存路径。所以在实际使用,需要根据实际情况修改保存路径。另外还需要处理异常情况,例如文件上传失败的情况。 以上就是基于注解使用Spring MVC实现文件上传的简单示例。通过使用@RequestParam注解来接收上传文件,我们可以轻松地实现文件上传功能。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值