2

我想在 grails 上使用 groovy 上传图像。我的gsp页面如下(我展示的是原版的简化版)

<g:form controller="post" action="save" enctype="multipart/form-data">        
      My picture  <input type="file" name="myPicture" />     
    <g:submitButton name="submit" value="Save"/>
</g:form>

我的域类如下:

class Post {    

byte[] myPicture

static mapping = {
    myPicture type:  "blob" 
}

我需要这个映射,否则 MySql 将创建一个小到适合图像的 smallblob

static constraints = {
    myPicture(nullable:false)      
}

}

在控制器上,我有一个名为 save 的操作,如下所示:

def save = {                               
    def post = loadPost(params.id)

    post.properties = params

    if(post.save()) {
        print "hallo world"             
        redirect(action:'list', params:params)
    } else {
        render(view:'edit', model:[post:post])
    }
}

当我尝试将图像保存在数据库中时引发异常。

2009-04-27 18:16:07,319 [20806951@qtp0-0] ERROR errors.GrailsExceptionResolver  - java.lang.ClassCastException: [B cannot be cast to java.sql.Blob

org.codehaus.groovy.runtime.InvokerInvocationException: java.lang.ClassCastException: [B 不能转换为 java.sql.Blob

任何提示这是为什么?

顺便说一句,我在教程中看到图像被处理为字符串,但效果不佳。

4

3 回答 3

2

我在 Nabble 上发现了一个类似的问题:

http://www.nabble.com/MySQL-and-Blobs-td16116885.html

提出了两种可能的解决方案:

  • 将 blob 属性的约束更改为较大的最大大小,以阻止它使用“TinyBlob”。
  • 使用 Hibernate Blob 实现而不是 byte[] 作为属性的类型声明。这将要求您将数据流式传输到 Blob,而不是直接分配,但上面的帖子提供了这样做的代码。
于 2009-04-27T17:03:21.903 回答
2

您可以尝试在您的方法中使用 Spring 的MultipartFile吗?loadPost()

这是文档中的一个示例:

def upload = {
    def f = request.getFile('myFile')
    if(!f.empty) {
      f.transferTo( new File('/some/local/dir/myfile.txt') )
      response.sendError(200,'Done');
    }    
    else {
       flash.message = 'file cannot be empty'
       render(view:'uploadForm')
    }
}

我相信你可以f.bytes直接访问。

于 2009-04-27T17:17:47.577 回答
1

试试这种方式:

  def save = {                               

    def post = loadPost(params.id)

    def f = request.getFile('myPicture')             

    post.myPicture = f.getBytes()
    post.pictureType = f.getContentType()                    


    if(post.save()) {
于 2009-05-04T09:20:55.043 回答