MongoDB Java Driver 源码分析(12):GridFSFile、GridFSDBFile 和 GridFSInputFile

  GridFSFile 类表示 GridFS 中的文件的信息,它是一个抽象类,分别被 GridFSDBFile (表示从数据库中读取的文件) 和 GridFSInputFile(表示将要保存到数据库中的文件 ) 继承。

  GridFSFile 类包含下列属性(相应地有一系列的 get 方法)
[code]
Object _id; // 文件的唯一标识
String _filename; // 文件的名称
String _contentType; // 文件内容类型
long _length; // 文件长度
long _chunkSize; // 文件分块大小
Date _uploadDate; // 更新时间
List<String> _aliases; // 别名
DBObject _extradata = new BasicDBObject(); //额外信息
String _md5; // md5 值
[/code]
  此外它还提供保存文件信息的 save 方法:
[code]
// 保存文件
public void save(){
if ( _fs == null )
throw new MongoException( "need _fs" );
_fs._filesCollection.save( this );
}
[/code]
[size=medium][align=center][b]GridFSDBFile (从数据库中读取的文件)[/b][/align][/size]
  【将文件写入输出流】

  GridFSDBFile 的 writeTo 方法可以将文件写入输出流,以达到读取文件数据的目的。
[code]
// 将文件写入输出流
public long writeTo( OutputStream out )
throws IOException {
final int nc = numChunks();

// 遍历文件块,一次写入到输出流中
for ( int i=0; i<nc; i++ ){
out.write( getChunk( i ) );
}
return _length;
}

// 获取特定的文件块
byte[] getChunk( int i ){
if ( _fs == null )
throw new RuntimeException( "no gridfs!" );

// 调用 GridFS 的 _chunkCollection 的 findOne 方法
// _chunkCollection 中存放了文件数据
// 查询时指定了参数 files_id (文件的唯一标识) 和 n (序号)
DBObject chunk = _fs._chunkCollection.findOne( BasicDBObjectBuilder.start( "files_id" , _id ).add( "n" , i ).get() );
if ( chunk == null )
throw new MongoException( "can't find a chunk! file id: " + _id + " chunk: " + i );

// 获取文件块数据
return (byte[])chunk.get( "data" );
}
[/code]

  【获取输入流】

  另一种读取数据的方式是直接获取输入流。

[code]
// 获取输入流,用于读取数据
public InputStream getInputStream(){
return new MyInputStream();
}
[/code]
GridFSFile.MyInputStream 的 read 方法实现如下:
[code]
// 读取数据
// b 存放数据的字节数组
// off 偏移量
// len 长度
public int read(byte[] b, int off, int len){
// 偏移量超过文件大小
if ( _data == null || _offset >= _data.length ){
// 已经读完
if ( _nextChunk >= _numChunks )
return -1;

// 读取一块数据,以备使用
_data = getChunk( _nextChunk );
_offset = 0;
_nextChunk++;
}

// r:将要读取的数据的长度
int r = Math.min( len , _data.length - _offset );

// 将 _data 中指定偏移量和长度的数据复制到 b 中
System.arraycopy( _data , _offset , b , off , r );

// 增加偏移量
// 在 MyInputStream 内部记录当前的数据块读取到哪里了
// 下次再从这里开始读取
_offset += r;

// 返回读取的长度
return r;
}
[/code]

  【删除操作】

  GridFSDBFile 还提供从 GridFS 中删除文件的方法,实际上相当于调用 GridFS 的 remove 方法。
[code]
// 从 GridFS 的 _filesCollection 和 _chunkCollection 中删除文件
// 与 GridFS.remove 方法的实现相似, 实际上相当于调用 _fs.remove(_id)
void remove(){
_fs._filesCollection.remove( new BasicDBObject( "_id" , _id ) );
_fs._chunkCollection.remove( new BasicDBObject( "files_id" , _id ) );
}
[/code]
[size=medium][align=center][b]GridFSInputFile 准备写入数据库的文件[/b][/align][/size]
  GridFSInputFile 可以获得输出流,从而写入需要保存的数据,写入完毕后通过 close 方法提交修改。
[code]
// 获取输出流
public OutputStream getOutputStream() {
if ( _outputStream == null ) {
_outputStream = new MyOutputStream();
}
return _outputStream;
}
[/code]

  GridFSInputFile.MyOutputStream 的 write 方法的实现如下:
[code]
public void write( byte[] b , int off , int len ) throws IOException {
int offset = off;
int length = len;
int toCopy = 0;
while ( length > 0 ) {
// 计算每次需要写入的长度
toCopy = length;
if ( toCopy > _chunkSize - _currentBufferPosition ) {
toCopy = (int) _chunkSize - _currentBufferPosition;
}

// 复制数据
System.arraycopy( b, offset, _buffer, _currentBufferPosition, toCopy );

// 修改偏移量
_currentBufferPosition += toCopy;
offset += toCopy;
length -= toCopy;

// 已经到达文件块的结尾,写入数据库
if ( _currentBufferPosition == _chunkSize ) {
_dumpBuffer( false );
}
}
}

// 将缓冲区中的数据写入数据库中
// writePartial 为 true 表示不写入整块的数据,这通常用于写入文件数据的结尾部分。
private void _dumpBuffer( boolean writePartial ) {
if ( ( _currentBufferPosition < _chunkSize ) && !writePartial ) {
// 文件块不完整,返回
return;
}
if (_currentBufferPosition == 0) {
// 块为空,返回
return;
}

// 复制数据
byte[] writeBuffer = _buffer;
if ( _currentBufferPosition != _chunkSize ) {
writeBuffer = new byte[_currentBufferPosition];
System.arraycopy( _buffer, 0, writeBuffer, 0, _currentBufferPosition );
}

// 保存文件数据到数据库
DBObject chunk = BasicDBObjectBuilder.start()
.add( "files_id", _id )
.add( "n", _currentChunkNumber )
.add( "data", writeBuffer ).get();
_fs._chunkCollection.save( chunk );

// 改变偏移量等收尾工作
_currentChunkNumber++;
_totalBytes += writeBuffer.length;
_messageDigester.update( writeBuffer );
_currentBufferPosition = 0;
}
[/code]
  需要特别注意的是以下语句:
[code]
// 保存文件数据到数据库
DBObject chunk = BasicDBObjectBuilder.start()
.add( "files_id", _id )
.add( "n", _currentChunkNumber )
.add( "data", writeBuffer ).get();
_fs._chunkCollection.save( chunk );
[/code]
  借助 DBCollection.save 保存了数据。构造的 DBObject 包含三个属性:files_id (文件标识)、n(文件块序号)和 data(文件数据)
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: Java MongoDB DriverMongoDB 官方提供的 Java 驱动程序,用于连接和操作 MongoDB 数据库。目前最新版本为 4.x。 要下载 Java MongoDB Driver 4.x,可以按照以下步骤进行: 1. 打开 MongoDB 官网的下载页面(https://www.mongodb.com/try/download/drivers/java)。 2. 在页面中找到 Java 驱动程序部分。 3. 点击"Download"按钮,会弹出一个对话框,选择希望下载的版本和文件类型(例如 JAR 或 POM)。 4. 点击"Download"按钮下载驱动程序。 5. 下载完成后,将下载的驱动程序文件添加到你的 Java 项目中。 在使用 Java MongoDB Driver 时,需要注意以下几点: 1. 确保你的项目已经添加了正确的驱动程序依赖。如果使用 Maven 进行项目管理,可以在 pom.xml 文件中添加以下依赖项: ```xml <dependency> <groupId>org.mongodb</groupId> <artifactId>mongodb-driver-sync</artifactId> <version>4.x.x</version> </dependency> ``` 2. 在代码中使用 MongoDB 驱动程序提供的 API 来连接和操作数据库。例如,可以使用以下代码来连接 MongoDB 数据库: ```java import com.mongodb.client.MongoClients; import com.mongodb.client.MongoClient; import com.mongodb.client.MongoDatabase; public class MongoDBExample { public static void main(String[] args) { MongoClient client = MongoClients.create("mongodb://localhost:27017"); MongoDatabase database = client.getDatabase("mydb"); // 进行数据库操作... client.close(); } } ``` 这样就完成了 Java MongoDB Driver 4.x 的下载和使用。可以根据项目的需求,使用更高级的 API 进行更丰富的 MongoDB 数据库操作。 ### 回答2: Java MongoDB DriverMongoDB 官方提供的 Java 语言的客户端驱动程序,用于与 MongoDB 数据库进行通信和交互。当前最新版本是 4.。 首先,你可以在 Maven 仓库中下载 Java MongoDB Driver 的依赖。你可以在项目的 Maven 配置文件(pom.xml)中添加如下依赖项: ```xml <dependencies> <dependency> <groupId>org.mongodb</groupId> <artifactId>mongodb-driver-sync</artifactId> <version>4.4.0</version> </dependency> </dependencies> ``` 或者,你也可以直接在 MongoDB 官方网站的 Java Driver 下载页面上下载最新版本的 Java MongoDB Driver。下载完成后,你可以将下载的 JAR 文件添加到你的项目的类路径下。 另外,你还需要下载 MongoDBJava 连接管理器(Java Connect Manager)JAR 文件,它是 MongoDBJava 驱动的核心组件。你同样可以在 Maven 仓库或 MongoDB 官方网站上找到并下载到相应的版本。 一旦你下载了 Java MongoDB Driver 的 JAR 文件,你就可以将它们添加到你的 Java 项目的类路径中。然后,你可以在代码中导入相关的 MongoDB 类和方法,以便使用 Java MongoDB Driver 来连接和操作 MongoDB 数据库。 总之,要下载 Java MongoDB Driver 4.,你可以通过 Maven 仓库或者在 MongoDB 官方网站找到相关的 JAR 文件。下载完成后,将它们添加到项目类路径中,并在代码中导入相关类和方法,就可以开始使用 Java MongoDB Driver 进行数据库操作了。 ### 回答3: Java MongoDB DriverMongoDB官方提供的Java语言的驱动库,用于连接和操作MongoDB数据库。在进行Java开发时,如果需要使用MongoDB数据库,就需要下载并引入Java MongoDB Driver来实现与数据库的交互。 Java MongoDB Driver的最新版本是4.x系列。下载Java MongoDB Driver 4.x的步骤如下: 1. 打开MongoDB官方网站,进入“Connectors”页面。 2. 在Java的部分找到Java MongoDB Driver的下载链接。 3. 点击下载链接,选择适合你操作系统/开发环境的版本。 4. 下载完成后,解压下载的文件。 在项目中使用Java MongoDB Driver 4.x的步骤如下: 1. 打开你的Java项目,进入项目的构建工具配置文件(如Maven的pom.xml文件)。 2. 在依赖配置中添加MongoDB Driver的引用。 示例(Maven配置): ``` <dependency> <groupId>org.mongodb</groupId> <artifactId>mongodb-driver-sync</artifactId> <version>4.4.1</version> </dependency> ``` 3. 保存并更新项目的依赖。 完成以上步骤后,你就可以在Java代码中使用Java MongoDB Driver 4.x来连接和操作MongoDB数据库了。根据具体需求,可以使用Driver提供的API进行数据的增删改查等操作。 总结:下载Java MongoDB Driver 4.x可通过MongoDB官方网站获取合适版本的驱动库,然后在项目的构建工具配置文件中添加依赖引用即可。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值