Python和MongoDB-如何按BinData类型查找

我是MongoDB的新手.无论如何,我正在尝试保存一些经过加密和base64编码的数据.

data = b64encode(self.iv + AES.new(self.key, self.mode, self.iv).encrypt(self.pad2(self.data)))
self.db.users.insert({'data':data})
self.db.users.find({'data':data})

插入工作正常,但查找数据返回0个结果. MongoDB shell输出以下内容:

db.users.find()
{ "_id" : ObjectId("50f848dc34257b0d5e3d9b29"), "data" : BinData(0,"R1VhaHl3MGpLSStkY0lWU255ZjhneGp2RWk3cEk3MnFRTCsxOTcyOC82WT0=")}

现在如何按BinData文件类型查找文档?我尝试过bson.binary.Binary那里没有运气.

解决方法:

不知道您是否仍然需要它(或者为什么要从二进制转换为base64,再转换为二进制),但是我希望这会有所帮助:

import base64
import pymongo
from pymongo import binary
# if pymongo version >= 1.9, use the following instead
# from bson import binary

con = pymongo.Connection()
b64 = base64.b64encode("ajskldfjaklsdjfklasdjf")
bi = binary.Binary(b64)
con.test.test.insert({'foo': bi})
con.test.test.find_one({'foo': bi})

输出:

{
    u'_id': ObjectId('50f99b4a9f956a1924000000'),
    u'foo': Binary('YWpza2xkZmpha2xzZGpma2xhc2RqZg==', 0)
}
上一篇:C# 通过Thrift访问Hbase


下一篇:将BSON对象的反序列化数组作为Java中的根对象?