SpringMVC实现文件上传下载,模板代码

SpringMVC下载代码

前提说明:本文后端使用SpringMVC,前端使用thymeleaf模板引擎发送请求
被下载的图片在项目中的路径:webapp/img/body.jpg
在这里插入图片描述
项目打包路径:…\target\spring_mvc_ajax\img\body.jpg,我们设置的路径主要以次路径来设置
在这里插入图片描述
代码实现

/**
 * ResponseEntity可以作为控制器方法的返回值,表示响应到浏览器的完整的响应报文
 */
@Controller
public class FileUpAndDownController {
    @RequestMapping("/test/down")
    public ResponseEntity<byte[]> testResponseEntity(HttpSession session) throws
            IOException {
        //获取ServletContext对象
        ServletContext servletContext = session.getServletContext();
        //获取服务器中文件的真实路径;更改下面方法中的路径即可
        String realPath = servletContext.getRealPath("img");
        //拼接具体文件的路径
        realPath = realPath + File.separator+"body.jpg";
        //创建输入流
        InputStream is = new FileInputStream(realPath);
        //创建字节数组,is.available()获取输入流所对应文件的字节数
        byte[] bytes = new byte[is.available()];
        //将流读到字节数组中
        is.read(bytes);
        //创建HttpHeaders对象设置响应头信息
        MultiValueMap<String, String> headers = new HttpHeaders();
        //Content-Disposition:设置要下载方式;attachment表示以附件方式下载,filename下载下来文件的默认名字
        headers.add("Content-Disposition", "attachment;filename=body.jpg");
        //设置响应状态码
        HttpStatus statusCode = HttpStatus.OK;
        //创建ResponseEntity对象
        ResponseEntity<byte[]> responseEntity = new ResponseEntity<>(bytes, headers,
                statusCode);
        //关闭输入流
        is.close();
        return responseEntity;
    }
}

前台访问该请求代码(此处使用了thymeleaf模板引擎的请求方式)

<a th:href="@{/test/down}">下载图片</a>

SpringMVC上传代码

1.引入文件上传依赖(若未使用maven的小伙伴需要自行百度下载下方名字的jar包引入)

<dependency>
      <groupId>commons-fileupload</groupId>
      <artifactId>commons-fileupload</artifactId>
      <version>1.3.1</version>
    </dependency>

2.springmvc.xml核心配置文件配置一个bean组件:文件上传解析器

<!--配置文件上传解析器,其id必须为multipartResolver-->
    <bean id="multipartResolver" class="org.springframework.web.multipart.commons.CommonsMultipartResolver">
        <property name="defaultEncoding" value="UTF-8"></property>
    </bean>

3.前端代码(以thymeleaf模板引擎请求)
前提要求:需要使用表单,使用表单文件域上传;表单请求方式必须为post;表单enctype属性必须设置为 multipart/form-data

<!--    multipart/form-data将表单数据以2进制提交到表单中-->
    <form th:action="@{/test/up}" method="post" enctype="multipart/form-data">
        文件:<input type="file" name="photo"></br>
        <input type="submit" value="提交">
    </form>

4.后端代码

@RequestMapping("test/up")
    public String testUp(MultipartFile photo, HttpSession session) throws IOException {
        //获取上传文件的文件名
        String fileName = photo.getOriginalFilename();
        //使用UUID处理文件重名问题
        //1.substring获取上传的文件的后缀名;substring是“包前不包后的,即截取包含.到末尾的值”
        String hzName = fileName.substring(fileName.lastIndexOf("."));
        //获取UUID
        String uuid = UUID.randomUUID().toString();
        //拼接一个新的文件名
        fileName = uuid + hzName;
        //获取servletContext对象
        ServletContext context = session.getServletContext();
        //获取当前工程下(服务器下)photo目录的真实路径
        String photoPath = context.getRealPath("photo");
        //创建photoPath所对应的File对象
        File file = new File(photoPath);
        //判断file所对应的路径是否存在,若不存在则创建目录
        if (!file.exists()){
            file.mkdir();
        }
        //拼接文件全路径:即存放地址+文件名
        String finalPath = photoPath+File.separator+fileName;
        //使用transferTo上传文件  
        photo.transferTo(new File(finalPath));
        //跳转到seccess.html页面
        return "success";
    }

参考资料:B站UP尚硅谷

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值