Java实现数据库图片上传(包含从数据库拿图片传递前端渲染)-图文详解
以下是一个简化的Java后端代码示例,用于处理图片上传和从数据库获取图片以供前端渲染的请求。
import org.springframework.web.bind.annotation.*;
import org.springframework.http.ResponseEntity;
import org.springframework.core.io.Resource;
import org.springframework.core.io.ByteArrayResource;
import org.springframework.jdbc.core.JdbcTemplate;
import javax.sql.DataSource;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.Base64;
@RestController
public class ImageController {
private final JdbcTemplate jdbcTemplate;
public ImageController(DataSource dataSource) {
this.jdbcTemplate = new JdbcTemplate(dataSource);
}
// 上传图片接口
@PostMapping("/upload-image")
public String uploadImage(@RequestParam("image") byte[] image) {
String sql = "INSERT INTO images (image) VALUES (?)";
jdbcTemplate.update(sql, new Object[] { image });
return "Image uploaded successfully";
}
// 获取图片接口
@GetMapping("/get-image/{id}")
public ResponseEntity<Resource> getImage(@PathVariable("id") int id) throws SQLException {
String sql = "SELECT image FROM images WHERE id = ?";
byte[] image = jdbcTemplate.queryForObject(sql, new Object[] { id }, byte[].class);
Resource resource = new ByteArrayResource(image) {
@Override
public String getFilename() {
// 返回图片的文件名,如果有需要
return "image.png";
}
};
return ResponseEntity.ok().body(resource);
}
}
在这个示例中,我们定义了两个简单的API端点:/upload-image
用于上传图片,/get-image/{id}
用于根据ID获取图片。在实际应用中,你需要确保数据库已经创建,并且有一个名为images
的表,该表至少包含id
(主键)和image
(存储图片的BLOB字段)。
请注意,这个示例没有包含数据库连接的配置,异常处理,安全性考虑(比如验证用户是否有权限上传或获取图片),以及其他Spring Boot特定的配置,如全局异常处理器、数据库连接设置等。在实际应用中,你需要实现这些功能以保证安全性和稳定性。
评论已关闭