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

时间:2015-03-19 19:26:11

标签: grails

我正在编写一个grails(v2.4.4)应用程序来存储音乐库中歌曲的信息。其中一个"属性"一首歌就是"键"。所以我想编写一个包含所有有效密钥的验证/查找表(域类)。由于并非所有进行数据输入的人都会自动知道1 Flat的员工是F大比例/关键字我希望将员工的图像作为比较包含

(我无法粘贴工作人员的图像,还不够#34;积分"如果您有兴趣,可以在wikepedia中查看工作人员示例。http://en.wikipedia.org/wiki/F_major

我可以将这个文件作为BLOB存储到MySQL表中 - grails就可以了。但我不能为我的生活(使用我发现的许多例子)将图像带到"显示"。我在"有效密钥列表"中看到的所有内容是"字节"的字符串。有人可以指出我正确的方向。

ValidKeys Domain Class:

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))
    }
}

ValidKeysControler:(标准"生成"控制器)

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 }
        }
    }
}

3 个答案:

答案 0 :(得分:0)

你几乎就在那里。在评论中提到的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类型,无论出于何种原因,您都可以使用内容类型&#34; application / octet-stream&#34; (表示二进制文件)并指定文件名:

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() 
}

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

答案 1 :(得分:0)

谢谢你克里斯。

我实际上只是在“show.gsp”中使用了它。我没有添加“contentType”来使其工作,但我想我会回去添加该域字段和相应的代码,因为我发现的大多数示例似乎都包含它。

我做的工作是:

    控制器中的
  1. “def displayStaffImage()
    • 将File.get(params.id)更改为ValidKeys.findById(params.id)
  2. 在“ show.gsp ”中使用了标记
    • <span class="property-value" aria-labelledby="staffImg-label"><img src="${createLink(controller:'ValidKeys', action:'displayStaffImage', id:"${validKeysInstance.id}") }" width='100'/></span>
    • BTW,“span”部分是从“generate”步骤中的其他“字段”克隆的。这不是必要的,但我想我会努力保持一致。
  3. ...然而 同样不适用于“index.gsp”。我不喜欢这里的“id”作为参数。如果我有成功,我会尝试更多的想法并发布。但是,如果有任何指针要求在“index.gsp”中显示实际图像,我将不胜感激。

    再次感谢克里斯!

答案 2 :(得分:0)

这对我有用 我在域

中有这个列类型
/bin/sparkling-shell.cmd

我得到了结果

class User implements Serializable {
    Blob userPic
}