当前位置:首页 » 《随便一记》 » 正文

Spring MVC 图片的上传和下载

19 人参与  2023年04月06日 17:49  分类 : 《随便一记》  评论

点击全文阅读


在这里插入图片描述

✅作者简介:2022年博客新星 第八。热爱国学的Java后端开发者,修心和技术同步精进。
?个人主页:Java Fans的博客
?个人信条:不迁怒,不贰过。小知识,大智慧。
?当前专栏:SSM 框架从入门到精通
✨特色专栏:国学周更-心性养成之路
?本文内容:Spring MVC 图片的上传和下载

文章目录

序言思路一:浏览器图片的上传下载显示通过本地实现1、图片上传功能2、图片下载功能 思路二:浏览器图片的上传下载显示通过数据库实现1、将图片添加到数据库第二步:从数据库读取到前端页面

在这里插入图片描述

序言

  SSM 框架是一种基于Java的Web开发框架,其中Spring作为控制层、SpringMVC作为视图层、MyBatis作为持久层,这个框架非常适合Web应用程序的开发。在这篇文章中,我们将使用 SSM 框架来实现图片的上传和下载功能。

  首先,我们需要准备好一个基本的SSM框架环境,也就是需要一个Tomcat服务器、Spring、SpringMVC和MyBatis等开发工具。

  接着创建一个名为Image的Java类来存储图片的信息。该类包含以下字段:id、name、path、size、createTime、type、等。

思路一:浏览器图片的上传下载显示通过本地实现

  下面我们来实现具体的功能:

1、图片上传功能

  在控制层中,我们创建一个名为UploadController的类来处理上传请求。在该类中,我们需要添加一个方法,该方法用于处理上传请求并返回上传结果。在该方法中,我们需要使用SpringMVC提供的 MultipartResolver 类来解析上传的文件,获取文件信息,并将文件保存到服务器上。以下是UploadController类中的代码:

@Controller@RequestMapping("/upload")public class UploadController {    @RequestMapping(value = "/image", method = RequestMethod.POST)    @ResponseBody    public String uploadImage(@RequestParam("file") MultipartFile file) {        String fileName = file.getOriginalFilename();        String path = "D:/uploads/" + fileName;        try {            File dest = new File(path);            if (!dest.getParentFile().exists()) {                dest.getParentFile().mkdirs();            }            file.transferTo(dest);            return "success";        } catch (Exception e) {            e.printStackTrace();            return "error";        }    }}

2、图片下载功能

  在控制层中,我们创建一个名为DownloadController的类来处理下载请求。在该类中,我们需要添加一个方法,该方法用于处理下载请求并返回下载结果。在该方法中,我们需要使用SpringMVC提供的 ResponseEntity 类来返回文件流并设置相关的头信息。以下是DownloadController类中的代码:

@Controller@RequestMapping("/download")public class DownloadController {    @RequestMapping(value = "/image/{id}", method = RequestMethod.GET)    public ResponseEntity<byte[]> downloadImage(@PathVariable("id") int id) {        Image image = imageService.getImageById(id);        String fileName = image.getName();        String path = "D:/uploads/" + fileName;        try {            HttpHeaders headers = new HttpHeaders();            headers.setContentType(MediaType.APPLICATION_OCTET_STREAM);            headers.setContentDispositionFormData("attachment", fileName);            File file = new File(path);            return new ResponseEntity<byte[]>(FileUtils.readFileToByteArray(file), headers, HttpStatus.CREATED);        } catch (Exception e) {            e.printStackTrace();            return null;        }    }}

  以上代码中,我们使用了 imageService.getImageById(id) 方法来获取要下载的图片的信息,这个方法可以自己实现或借助MyBatis框架读取数据库获取数据。

  最后,在SpringMVC的配置文件spring-servlet.xml中,添加以下配置信息,以支持文件上传和下载功能:

<!-- 文件上传配置 --><bean id="multipartResolver" class="org.springframework.web.multipart.commons.CommonsMultipartResolver">    <property name="maxUploadSize" value="10485760" /></bean><!-- 文件下载配置 --><mvc:resources mapping="/download/**" location="file:/D:/uploads/" />

  这样,我们就完成了图片上传和下载的功能实现。通过SSM框架的整合,我们可以很方便地实现文件上传和下载的功能。

思路二:浏览器图片的上传下载显示通过数据库实现

  SSM 将图片添加到数据库和从数据库读取到前端页面实质上是对数据库中的二进制数据进行操作,以下是常用的实现方式:

1、将图片添加到数据库

  (1)在数据库中添加一个表,用于存储图片数据,表结构如下:

CREATE TABLE tb_image(    `id` int(11) NOT NULL AUTO_INCREMENT COMMENT '主键',    `name` varchar(255) NOT NULL COMMENT '文件名',    `image` longblob NOT NULL COMMENT '图片数据',    PRIMARY KEY (`id`)) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COMMENT='图片表';

  其中,id为主键自增长,name用于存储文件名,image用于存储图片数据。

  (2)在 Java 代码中先读取图片数据,然后将其插入到数据库中,示例代码如下:

public void addImage(String name, String imagePath) {    try {        FileInputStream fis = new FileInputStream(imagePath);        PreparedStatement pstmt = conn.prepareStatement("INSERT INTO tb_image(name,image) VALUES(?,?)");        pstmt.setString(1, name);  // 设置文件名        pstmt.setBinaryStream(2, fis, fis.available());  // 设置图片数据        pstmt.executeUpdate();        pstmt.close();    } catch (Exception e) {        e.printStackTrace();    }}

  其中,name为文件名,imagePath为图片路径,fis为读取图片数据的输入流,conn为数据库连接对象。

第二步:从数据库读取到前端页面

  (1)在 Java 代码中从数据库中读取图片数据,示例代码如下:

public void getImage(int id, HttpServletResponse response) {    try {        PreparedStatement pstmt = conn.prepareStatement("SELECT * FROM tb_image WHERE id=?");        pstmt.setInt(1, id);        ResultSet rs = pstmt.executeQuery();        if (rs.next()) {            String name = rs.getString("name");            Blob imageBlob = rs.getBlob("image");            InputStream is = imageBlob.getBinaryStream();            ServletOutputStream out = response.getOutputStream();            response.setContentType("image/jpeg");            response.setHeader("Content-Disposition", "attachment;filename=" + name);            byte[] b = new byte[1024];            int len;            while ((len = is.read(b)) > 0) {                out.write(b, 0, len);            }            is.close();            out.flush();            out.close();        }        rs.close();        pstmt.close();    } catch (Exception e) {        e.printStackTrace();    }}

  其中,id 为图片在数据库中的对应主键,response 为响应对象,conn 为数据库连接对象。通过操作 ResultSet 对象可以得到图片数据的输入流。

  (2)在前端页面中调用此 Java 方法,将图片数据显示在页面上,示例代码如下:

<img src="/getImage?id=1" />

  其中,getImage 方法的 id 参数表示图片在数据库中的主键值。在前端页面中使用 img 标签,指定 src 属性为 getImage 方法的 url 地址即可


  码文不易,本篇文章就介绍到这里,如果想要学习更多Java系列知识点击关注博主,博主带你零基础学习Java知识。与此同时,对于日常生活有困扰的朋友,欢迎阅读我的第四栏目:《国学周更—心性养成之路》,学习技术的同时,我们也注重了心性的养成。

在这里插入图片描述


点击全文阅读


本文链接:http://zhangshiyu.com/post/58664.html

<< 上一篇 下一篇 >>

  • 评论(0)
  • 赞助本站

◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。

最新文章

  • 全书浏览悔婚当日,清冷权臣求我别始乱终弃:结局+番外火爆情节(宗肆宁芙)_悔婚当日,清冷权臣求我别始乱终弃:结局+番外火爆情节(宗肆宁芙)全书结局
  • [顶级伪装,全京城都为她神魂颠倒]节选试读_[鹿桑顾漾]命运转折章节速览
  • 悔婚当日,清冷权臣求我别始乱终弃:结局+番外火爆情节(宗肆宁芙)_悔婚当日,清冷权臣求我别始乱终弃:结局+番外火爆情节宗肆宁芙
  • 八零高原之上爱意缺氧:+结局+番外(江念予仁钦桑吉)_八零高原之上爱意缺氧:+结局+番外
  • 星光不及你深情限免完整章节合集‌_[陈庭序颜如月]反转剧情试读片段
  • 全书浏览晚风絮:+后续+(傅霖姜羽絮)_晚风絮:+后续+(傅霖姜羽絮)全书结局
  • 完结文一枕清梦付东河江彦辰宋凝霜完结篇潜心更新列表_完结文一枕清梦付东河江彦辰宋凝霜完结篇潜心更新
  • [狂龙归来,美女总裁沦陷了]精彩节选试读_江川沈青霜后续在线阅读
  • [不走寻常路的妹妹]后续全文免费阅读_「刘清李言」小说节选免费试读
  • 宋芷芸傅清彦:+结局+番外精心打造列表_宋芷芸傅清彦:+结局+番外精心打造
  • 海棠仍俏倚朱栏:+后续+结局全面完结(傅逸辰沈长清)_海棠仍俏倚朱栏:+后续+结局全面完结
  • (番外)+(全书)唯独你是情之所钟:结局+番外(林清颜梁敬楠)_唯独你是情之所钟:结局+番外列表_笔趣阁(林清颜梁敬楠)

    关于我们 | 我要投稿 | 免责申明

    Copyright © 2020-2022 ZhangShiYu.com Rights Reserved.豫ICP备2022013469号-1