PouchDB – 添加附件
PouchDB – 添加附件
您可以使用PouchDB 中的putAttachment()方法将二进制对象附加到文档。
句法
以下是putAttachment()的语法。对于此方法,我们必须将文档 id、附件 id、MIME 类型与附件一起传递。此方法还接受一个可选的回调函数。
db.putAttachment( docId, attachmentId, attachment, type, [callback] );
我们可以使用 blob 或缓冲区对象准备附件,其中blob在使用浏览器时使用,缓冲区在使用Node.js 时使用,因为我们在 Node.js 中演示我们的程序,所以我们使用缓冲区对象来准备文档。
例子
以下是使用putAttachment()方法在 PouchDB 中名为my_database的数据库中创建带有附件的文档的示例。
//Requiring the package
var PouchDB = require('PouchDB');
//Creating the database object var db = new PouchDB('my_database');
//Preparing the attachment
var my_attachment = new Buffer(['Welcome to tutorialspoint'], {type: 'text/plain'});
//Adding attachment to a document
db.putAttachment('001', 'att_1.txt', my_attachment, 'text/plain', function(err, res) {
if (err) {
return console.log(err);
} else {
console.log(res+"Attachment added successfully")
}
});
将上述代码保存在名为Add_Attachment.js的文件中。打开命令提示符并使用node执行 JavaScript 文件,如下所示。
C:\PouchDB_Examples >node Add_Attachment.js
这会在名为my_database的数据库中创建一个向其添加附件的空文档,该数据库存储在 PouchDB 中,并显示以下消息。
Attachment added successfully
您可以使用以下代码通过阅读文档来验证是否添加了附件。
//Requiring the package
var PouchDB = require('PouchDB');
//Creating the database object var db = new PouchDB('my_database');
//Reading the Document
db.get('001',{attachments: true}, function(err, doc) {
if (err) {
return console.log(err);
} else {
console.log(doc);
}
});
将上述代码另存为read_doc.js并执行。执行这个程序,可以看到文档如下内容。
{
_attachments: {
att_1.txt: {
content_type: 'text/plain',
digest: 'md5-k7iFrf4NoInN9jSQT9WfcQ==',
data: 'AA=='
}
},
_id: '001',
_rev: '1-620fd5f41d3328fcbf9ce7504338a51d'
}
向现有文档添加附件
假设数据库中有一个名为my_database PouchDB 且 ID 为“ 002 ”的文档。您可以通过将 id 值更改为002来执行read_doc.js来获取它的内容,如下所示。
{
name: 'Raju',
age: 23,
designation: 'Designer',
_id: '002',
_rev: '1-05ca7b5f3f4762a9fb2d119cd34c8d40'
}
现在,您可以使用其_rev值向该文档添加附件。
//Requiring the package
var PouchDB = require('PouchDB');
//Creating the database object var db = new PouchDB('my_database');
//Adding attachment to existing document
var my_attachment = new Buffer (['Welcome to tutorialspoint'], {type: 'text/plain'});
rev = '1-05ca7b5f3f4762a9fb2d119cd34c8d40';
db.putAttachment('002', 'att_1.txt', rev, my_attachment, 'text/plain', function(err, res) {
if (err) {
return console.log(err);
} else {
console.log (res + "Attachment added successfully")
}
});
将上述代码保存在名为Add_Attachment_to_doc.js的文件中。打开命令提示符并使用node执行 JavaScript 文件,如下所示。
C:\PouchDB_Examples >node Add_Attachment_to_doc.js
这会向指定的文档添加一个附件,显示以下消息。
Attachment added successfully
如果将read_doc.js 中的 id 值改为002并执行,将会得到如下输出。
{
name: 'Raju',
age: 23,
designation: 'Designer',
_attachments: {
att_1: {
content_type: 'text/plain',
digest: 'md5-k7iFrf4NoInN9jSQT9WfcQ==',
data: 'AA=='
}
},
_id: '002',
_rev: '2-3bb4891b954699bce28346723cc7a709'
}
向远程文档添加附件
您甚至可以向远程存储在服务器 (CouchDB) 上的数据库中现有的文档添加附件。
为此,您需要将路径传递到 CouchDB 中包含要读取的文档的数据库的路径,而不是数据库名称。
例子
假设在 CouchDB 服务器中有一个名为my_database的数据库。然后,如果您使用 URL http://127.0.0.1:5984/_utils/index.html验证 CouchDB 中的数据库列表,您将获得以下屏幕截图。

如果选择名为my_database的数据库,则可以查看其内容,如下所示。

以下是向存储在名为my_database的数据库中的文档001添加附件的示例,该数据库存储在 CouchDB 服务器中。
//Requiring the package
var PouchDB = require('PouchDB');
//Creating the database object
var db = new PouchDB('http://localhost:5984/my_database');
//Adding attachment to existing document
var my_attachment = new Buffer (['Welcome to tutorialspoint'], {type: 'text/plain'});
rev = '1-36c34fdcf29a652876219065f9681602';
db.putAttachment('001', 'att_1.txt',rev, my_attachment, 'text/plain', function(err, res) {
if (err) {
return console.log(err);
} else {
console.log (res+ "Attachment added successfully")
}
});
将上述代码保存在名为Remote_Add_Attachment.js的文件中。打开命令提示符并使用node执行 JavaScript 文件,如下所示。
C:\PouchDB_Examples >node Remote_Add_Attachment.js
这会向指定的文档添加一个附件,显示以下消息。
Attachment added successfully
现在,如果您验证文档,您可以观察添加到其中的附件,如下面的屏幕截图所示。