db4o 转载 - 疯狂 --专注java,开源,架构,项目管理 - BlogJava
Android与db4o的完美结合-Password Manager
项目简介
这里提供的Password Manager项目是Steven Osborn编写的PasswordSafe(在Apache License下发行)的改写版,目前已经实现了在Android平台下的基本密码管理功能。项目源代码中使用db4o代替了SQLite,这样不但使持久化处理更为直观,而且使开发过程更快速、整个应用更加高效。
在这个项目中,你可以获得以下资源:
* db4o与SQLite之间在基本持久化操作上的比较
* 完整的Android示例应用代码
* 应用运行时的视频演示
基本功能
本应用基本功能是安全地保存网站登录信息,例如URL、用户名、密码,它使用128位AES加密算法。使用者必需提供正确的密码才能访问应用,而密码被用于加密/解密应用数据。
这里提供了采用db4o技术的Password Manager在Android模拟器下运行的在线视频:
http://www.youtube.com/watch?v=UFSD44AcBwM
如果你下载了源代码(请见本页末尾的详细说明),那么你会看到原来PasswordSafe中的DBHepler类(实现SQLite下的持久化)已经被替换为Db4oHelper类(实现db4o的持久化)。现在,就让我为你展示db4o和SQLite在持久化处理上的不同之处吧。
SQL初始化开销
这是你需要在SQLite下初始化密码管理器SQL代码(表名、表创建命令等):
而下面是等价的db4o代码:
正如你所看到的,在db4o中无需预定义schema(你可以将db4o对象模式当作schema使用,并且在这种对象模型下进行重构是非常优雅的,甚至在一些简单的情况下是自动化的)。
数据库打开和创建机制
在SQLite中,你需要调用两种不同的方法,一种是创建数据库,另一种是打开数据库:
而在db4o中,你只需要调用openFile(),它将根据数据库是否存在来创建或者打开数据库:
也许这里的差别看起来无关紧要,但更简短的代码才是更清晰的代码!
更新和插入数据
使用关系数据库SQLite时,你需要根据具体情况传送插入或更新命令(完全正确地构造反射数据表字段的SQL字符串确并非易事):
这里是等价的db4o代码:
你是否发现了不同?db4o实际上是一种单行代码(one-line-of-code)的存储数据库。db4o自动检查对象是新的还是已存在的,并根据对象状态进行更新或者插入(我们只需要调用set操作)。值得注意的是,在上面的代码中我们手工提供了对象的新id,而db4o是可以将其配置为自增字段的。
查询所有记录
在SQLite中,我们不得不进行人工的对象关系映射:
而在db4o中,我们完全可以忘掉关系映射:
请注意:在上面简短的查询中,我们通过db4o的SODA查询了全部PassEntry对象,并将结果按照"id"字段进行排序(在上面的SQLite示例中没有排序)。
它不能再简单了!
通过字段查询单一记录
通过Id查询记录的SQLite版本:
下面是db4o版本,它使用了db4o三种查询系统之一------Exmaple(也称为QBE)代替前面的SODA进行查询:
可以看出这是多么短小、清晰的代码啊!
结论
我希望你已经通过以上短小的文档了解到了db4o的优点。你希望在应用中将持久化提升到一个新的高度吗?请现在就下载db4oJava版本或者.NET版本吧!它是免费的!
相关资源
* db4o指南
* 安装向导
* 开发者资源
TODO
* 使用XTEA替换自定义加密算法(XTEA能够提供数据库级别加密和IO加密,而不是字段级加密)
* 提供检索功能(为了按名称进行过滤)
Steve的PasswordSafe项目发布在Google Code上,那里有更多的TODO:
http://code.google.com/p/android-passwordsafe/issues/
Bugs
* 在密码记录编辑器中尝试编辑website输入框中的URL时会发生错误。
源代码下载
Db4oAndroidPswMgr.Zip