gpt4 book ai didi

Grails 2.4.4 显示已存储在 MySQL 中的图像文件

转载 作者:行者123 更新时间:2023-12-02 16:02:28 26 4
gpt4 key购买 nike

我正在编写一个 grails (v2.4.4) 应用程序来将有关歌曲的信息存储在音乐库中。一首歌的“属性”之一是“键”。所以我想编写一个包含所有有效键的验证/查找表(域类)。由于不是每个进行数据输入的人都会自动知道带有 1 Flat 的五线谱是 F 大调音阶/调我想包括一张五线谱的图像作为比较

(我贴不上员工的图片,“积分”不够,有兴趣的可以看维基百科的员工示例。http://en.wikipedia.org/wiki/F_major)

我可以将此文件作为 BLOB 存储到 MySQL 表中——grails 可以做到这一点。但我不能为我的生活(使用我发现的许多例子)让图像“显示”。我在“有效 key 列表”中看到的只是“字节”字符串。有人可以指出我正确的方向吗?

ValidKeys 域类:

package musicdb

class ValidKeys {

String musicalKey
String aka
byte[] staffImg

static constraints = {
musicalKey (unique: true, nullable: false)
aka (nullable: true)
staffImg (nullable: true, maxSize: (1024*1024))
}
}

有效键 Controller : (标准“生成” Controller )
package musicdb

import static org.springframework.http.HttpStatus.*
import grails.transaction.Transactional

@Transactional(readOnly = true)
class ValidKeysController {

static allowedMethods = [save: "POST", update: "PUT", delete: "DELETE"]

def index(Integer max) {
params.max = Math.min(max ?: 10, 100)
respond ValidKeys.list(params), model:[validKeysInstanceCount: ValidKeys.count()]
}

def show(ValidKeys validKeysInstance) {
respond validKeysInstance
}

def create() {
respond new ValidKeys(params)
}

@Transactional
def save(ValidKeys validKeysInstance) {
if (validKeysInstance == null) {
notFound()
return
}

if (validKeysInstance.hasErrors()) {
respond validKeysInstance.errors, view:'create'
return
}

validKeysInstance.save flush:true

request.withFormat {
form multipartForm {
flash.message = message(code: 'default.created.message', args: [message(code: 'validKeys.label', default: 'ValidKeys'), validKeysInstance.id])
redirect validKeysInstance
}
'*' { respond validKeysInstance, [status: CREATED] }
}
}

def edit(ValidKeys validKeysInstance) {
respond validKeysInstance
}

@Transactional
def update(ValidKeys validKeysInstance) {
if (validKeysInstance == null) {
notFound()
return
}

if (validKeysInstance.hasErrors()) {
respond validKeysInstance.errors, view:'edit'
return
}

validKeysInstance.save flush:true

request.withFormat {
form multipartForm {
flash.message = message(code: 'default.updated.message', args: [message(code: 'ValidKeys.label', default: 'ValidKeys'), validKeysInstance.id])
redirect validKeysInstance
}
'*'{ respond validKeysInstance, [status: OK] }
}
}

@Transactional
def delete(ValidKeys validKeysInstance) {

if (validKeysInstance == null) {
notFound()
return
}

validKeysInstance.delete flush:true

request.withFormat {
form multipartForm {
flash.message = message(code: 'default.deleted.message', args: [message(code: 'ValidKeys.label', default: 'ValidKeys'), validKeysInstance.id])
redirect action:"index", method:"GET"
}
'*'{ render status: NO_CONTENT }
}
}

protected void notFound() {
request.withFormat {
form multipartForm {
flash.message = message(code: 'default.not.found.message', args: [message(code: 'validKeys.label', default: 'ValidKeys'), params.id])
redirect action: "index", method: "GET"
}
'*'{ render status: NOT_FOUND }
}
}
}

最佳答案

您快到了。在 displayStaffImage()您在评论中提到的方法,您还需要包含图像的 MIME 类型作为内容类型。

例如:

def displayStaffImage() { 
def validKeyInstance = File.get(params.id)
response.setContentType("image/png")
response.outputStream << validKeyInstance.staffImg
response.outputStream.flush()
}

请参阅 Grails: displaying created image in gsp 中接受的答案再举一个例子。

如果您不知道或不存储 MIME 类型,无论出于何种原因,您都可以使用内容类型“application/octet-stream”(表示二进制文件)并指定文件名:
def displayStaffImage() { 
def validKeyInstance = File.get(params.id)
response.setContentType("application/octet-stream")
response.setHeader("Content-disposition", "attachment;filename=\"${validKeyInstance.fileName}\"")
response.outputStream << validKeyInstance.staffImg
response.outputStream.flush()
}

编辑:我注意到您实际上并没有在 key 描述中存储文件名,所以也许我的第二个建议不那么相关,但如果您有可用的信息,它仍然是一个可行的选择。

关于Grails 2.4.4 显示已存储在 MySQL 中的图像文件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29153299/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com