设为首页 收藏本站
查看: 1165|回复: 0

[经验分享] grails将文件插入mongodb数据库

[复制链接]

尚未签到

发表于 2015-11-10 14:37:42 | 显示全部楼层 |阅读模式
  首先建立一个Domain class类。代码如下所示:
  import com.mongodb.WriteConcern
import org.bson.types.ObjectId
class FileItem {
static mapWith = "mongo"
static constraints = {
}
static mapping = {
writeConcern WriteConcern.FSYNC_SAFE
}
ObjectId id
String fileName         //文件名
String fileType         //文件类型
Long fileSize           //文件大小
String fileDescription  //文件描述
String fsId             //FSGrid存储ID
Date dateCreated //创建日期
Date lastUpdated //最后修改日期
String createdBy //创建人
String updatedBy //最后修改人
}


接下来需要一个公共类,将任何类型的本地文件都可以自动存入到数据库中去。
  Service类如下所示:
  import com.mongodb.gridfs.GridFS
import com.mongodb.gridfs.GridFSDBFile
import com.mongodb.gridfs.GridFSInputFile
import org.bson.types.ObjectId
/**
* 文件管理服务
* 通过Mongo GRIDFS 服务提供文件的存储
* 通过FileItem表记录真实文件名与GRID FS ID的关联
*/
class FileMgmtService {
static transactional = false
def mongo
def grailsApplication
def securityService
/**
* 上传文件保存到集中存储的地方
* @return
*/
FileItem saveFile(String fileName, byte[] fileData, String contentType, String fileDescription) {
//存储GridFS数据库
GridFS gridFS = new GridFS(mongo.getDB(grailsApplication.config.grails.mongo.databaseName))
GridFSInputFile gridFSInputFile = gridFS.createFile(fileData)
gridFSInputFile.filename = fileName
gridFSInputFile.contentType = contentType
gridFSInputFile.save()
//存储FileItem表
FileItem fileItem = new FileItem()
fileItem.fileDescription = fileDescription
fileItem.fileName = fileName
fileItem.createdBy = securityService.currentUserName
fileItem.dateCreated = new Date()
fileItem.fileSize = fileData.size()
fileItem.fileType = contentType
fileItem.fsId = gridFSInputFile.id.toString()
fileItem.save(flush: true, validate: false)
return fileItem
}
//删除文件必须通过该服务,同时删除FileItem和GridFS文件
void deleteFile(String fileItemId) {
FileItem fileItem = FileItem.findById(new ObjectId(fileItemId))
if(fileItem){
GridFS gridFS = new GridFS(mongo.getDB(grailsApplication.config.grails.mongo.databaseName))
gridFS.remove(new ObjectId(fileItem.fsId))
fileItem.delete()
}
}
//获取真正文件数据
byte[] getFileData(String fileItemId) {
FileItem fileItem = FileItem.findById(new ObjectId(fileItemId))
if(fileItem){
ByteArrayOutputStream byteArrayOutputStream = new ByteArrayOutputStream()
GridFS gridFS = new GridFS(mongo.getDB(grailsApplication.config.grails.mongo.databaseName))
GridFSDBFile gridFSDBFile = gridFS.find(new ObjectId(fileItem.fsId))
if(gridFSDBFile){
gridFSDBFile.writeTo(byteArrayOutputStream)
}
return byteArrayOutputStream.toByteArray()
}else{
return null
}
}
}

读取数据库中如果有国际化文件,则必须读取环境中相应的语言类型,然后进行选择。
  def getCurrentLocale() {
try {
def lang = RequestContextHolder.currentRequestAttributes().getSession().'org.springframework.web.servlet.i18n.SessionLocaleResolver.LOCALE'.language
if (lang) {
if (lang.startsWith('en')) {
return ParameterConstant.LOCALE_EN_US
}  else if (lang && lang.startsWith('zh')) {
return ParameterConstant.LOCALE_ZH_CN
}
} else {
return ParameterConstant.LOCALE_EN_US
}
} catch (Throwable e) {
return ParameterConstant.LOCALE_EN_US
}
}





版权声明:本文为博主原创文章,未经博主允许不得转载。

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-137621-1-1.html 上篇帖子: mongoose 操作mongodb数据库的 下篇帖子: mongodb数据库的使用-管理员管理-创建超级管理员以及登陆-直接验证登陆
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表