[英]How to insert an Image URL for Images stored in Postgres into a Spring Boot Model
我已经使用 Spring Boot Gradle Kotlin 后端构建了一个应用程序,它可以存储 Multipart 文件并将其上传到 Postgres 数据库。 数据存储在 ByteArray 中。 到目前为止,一切正常。
现在我想添加一个图像 URL 以使其在我的 JSON Object 中可用,然后像 Unsplash 上的那样在我的客户端显示它。
图片网址
"imageURL": "https://xyz.jpg"
文件 model
@Entity
@Table(name = "file")
data class File(
@Id
val id: UUID = UUID.randomUUID(),
val createdAt: LocalDateTime = LocalDateTime.now(),
var updatedAt: LocalDateTime = LocalDateTime.now(),
var likes: Int = 0,
var likedByUser: Boolean = false,
var description: String = "",
val downloadLink: URI = URI("https://unsplasy-backend.herokuapp.com/files/download/$id"),
var name: String = "",
var type: String = "",
@Basic(fetch = FetchType.LAZY)
private val data: ByteArray = byteArrayOf(),
val imageURL: TODO = "TODO"
)
店铺
fun store(file: MultipartFile): File {
val fileName = file.originalFilename.toString()
val fileToSave = File(
name = fileName,
type = file.contentType.toString(),
data = file.bytes
)
return fileRepository.save(fileToSave)
}
在阅读了上面的建议后,我想出了这个并且它有效。 Controller 更新
@GetMapping("/files/image/{id}")
fun displayImage(@PathVariable id: UUID, response: HttpServletResponse) {
val file = fileService.getFile(id)
val data = fileService.getData(file)
response.contentType = file.type
response.outputStream.write(data)
response.outputStream.close()
}
文件 Model 更新
val imageURL: URL = URL("https://unsplasy-backend.herokuapp.com/files/image/$id"),
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.