Java Web中上传图片以及显示图片的方法
Posted 空木幻城
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Java Web中上传图片以及显示图片的方法相关的知识,希望对你有一定的参考价值。
Java Web中上传图片以及显示图片的方法
环境需求
- jdk8+
- windows
- 开发工具
- postman
创建一个spring boot starter项目
- 打开你熟悉的开发工具,创建一个spring boot starter项目,只需要在pom.xml中加入spring web依赖即可
- 如果你创建的是maven项目,那么可以上官网,根据提示自动生成一个符合要求的pom.xml文件,替换掉原来的pom.xml文件即可
- pom.xml的内容如下(artifactId和groupId等请根据自己的情况设置)
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.5.3</version>
<relativePath/> <!-- lookup parent from repository -->
</parent>
<groupId>kmhc</groupId>
<artifactId>ImageUpload</artifactId>
<version>0.0.1-SNAPSHOT</version>
<name>ImageUpload</name>
<description>Image Upload Demo</description>
<properties>
<java.version>1.8</java.version>
</properties>
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
</dependency>
</dependencies>
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
</plugins>
</build>
</project>
编写获取图片的逻辑
- 先不着急写上传图片的逻辑,先写获取图片的逻辑,看看图片是否能够根据想想中的一样获取,具体代码如下(包名请根据情况自行决定)
package kmhc.api;
import java.awt.image.BufferedImage;
import java.io.File;
import java.io.FileInputStream;
import java.io.IOException;
import javax.imageio.ImageIO;
import org.springframework.http.MediaType;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.RestController;
@RestController
public class ImageController {
private static final String BASE_PATH = "D:\\\\workspace\\\\java\\\\ImageUpload\\\\src\\\\media";
@GetMapping(path = "/image/{filename}", produces = { MediaType.IMAGE_GIF_VALUE, MediaType.IMAGE_JPEG_VALUE,
MediaType.IMAGE_PNG_VALUE })
public BufferedImage getImage(@PathVariable("filename") String filename) throws IOException {
// 首先组合文件对象
File file = new File(BASE_PATH, filename);
// 判断文件是否存在
if (file.exists()) {
// 读取文件流,用文件流创建图片,这里也可以通过ImageIO直接读取文件
FileInputStream in = new FileInputStream(file);
BufferedImage image = ImageIO.read(in);
in.close();
return image;
} else {
// 如果不存在返回空
return null;
}
}
}
- 除了上面的代码以外,还需要提供BufferedImage的解析器,代码如下
package kmhc.config;
import java.util.List;
import org.springframework.context.annotation.Configuration;
import org.springframework.http.converter.BufferedImageHttpMessageConverter;
import org.springframework.http.converter.HttpMessageConverter;
import org.springframework.web.servlet.config.annotation.WebMvcConfigurer;
@Configuration
public class ImageConfig implements WebMvcConfigurer {
@Override
public void extendMessageConverters(List<HttpMessageConverter<?>> converters) {
converters.add(new BufferedImageHttpMessageConverter());
}
}
- 放一张图片在对应的文件夹中,如图所示
- 然后访问网页中的链接,此图对应的链接为http://127.0.0.1:8080/image/test.jpeg
- 可以看到访问成功,在前端中需要显示图片,将这个url引入进去就好了
编写上传图片的逻辑
- 上传图片的逻辑要稍微复杂一点,考虑到代码的鲁棒性,需要用条件判断语句做处理,完整代码如下
package kmhc.api;
import java.awt.image.BufferedImage;
import java.io.File;
import java.io.FileInputStream;
import java.io.IOException;
import java.util.UUID;
import javax.imageio.ImageIO;
import org.springframework.http.MediaType;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.RestController;
import org.springframework.web.multipart.MultipartFile;
@RestController
public class ImageController {
private static final String BASE_PATH = "D:\\\\workspace\\\\java\\\\ImageUpload\\\\src\\\\media";
/**
* 注意produces产出格式,如果没有对应类型则无法处理
* @param filename 图片名
* @return 图片流
* @throws IOException
*/
@GetMapping(path = "/image/{filename}", produces = { MediaType.IMAGE_GIF_VALUE, MediaType.IMAGE_JPEG_VALUE,
MediaType.IMAGE_PNG_VALUE })
public BufferedImage getImage(@PathVariable("filename") String filename) throws IOException {
// 首先组合文件对象
File file = new File(BASE_PATH, filename);
// 判断文件是否存在
if (file.exists()) {
// 读取文件流,用文件流创建图片,这里也可以通过ImageIO直接读取文件
FileInputStream in = new FileInputStream(file);
BufferedImage image = ImageIO.read(in);
in.close();
return image;
} else {
// 如果不存在返回空
return null;
}
}
/**
* 简单的上传逻辑,在实际运用中需要结合具体场景使用,有可能会存在上传新图片需要删除旧图片的情况,以及用户绑定图片url的情况
* @param file
* @throws IOException
*/
@PostMapping(value = "/image", produces = { MediaType.APPLICATION_JSON_VALUE, MediaType.IMAGE_GIF_VALUE, MediaType.IMAGE_JPEG_VALUE, MediaType.IMAGE_PNG_VALUE })
public void uploadImage(MultipartFile file) throws IOException {
// 获取文件夹对象
File folder = new File(BASE_PATH);
// 判断文件夹存不存在,不存在则创建
if (!folder.exists()) {
folder.mkdirs();
}
// 获取原文件名
String oldName = file.getOriginalFilename();
// 生成新文件名
String newName = UUID.randomUUID().toString() + oldName.substring(oldName.lastIndexOf("."));
// 保存图片
file.transferTo(new File(folder, newName));
}
}
- 打开postman,尝试上传一张图片,注意请求格式必须是post请求(这个要看具体情况,也有可能是patch),并且body格式是form-data
- 可以看到图片上传成功,并且名字也被改成了UUID了
问题点
- 如果提示404,那么有可能是服务没有重新启动的原因,需要手动重新服务才能生效
- 建议加入spring boot devtools依赖,可以热启动,代码保存后就重启服务,这一部分请自行上官网加入依赖
以上是关于Java Web中上传图片以及显示图片的方法的主要内容,如果未能解决你的问题,请参考以下文章
Java web项目从eclipse上移动到tomact服务器上,之路径更改,包括显示图片和导出excel
java web开发中 用户上传头像如何实现,尽量详细些。。。。谢谢各位大侠!