数据库开源框架之sqlcipher加密数据库
访问github链接:https://github.com/sqlcipher/android-database-sqlcipher
访问 http://sqlcipher.net/sqlcipher-for-android/ 查看官方介绍,
并从官方介绍中找出编译成功之后的zip压缩包进行下载
https://s3.amazonaws.com/sqlcipher/SQLCipher+for+Android+v3.1.0.zip
普通数据库
public interface MyDB { String name = "my.db";
int version = 1; public interface MyTable {
String name = "test";
String column_id = "_id";
String column_name = "name";
String create_sql = "create table " + name + "(" + column_id
+ " integer primary key autoincrement, " + column_name
+ " text)";
}
}
public class NativeOpenHelper extends SQLiteOpenHelper { public NativeOpenHelper(Context ctx) {
super(ctx, MyDB.name, null, MyDB.version);
} @Override
public void onCreate(SQLiteDatabase db) {
db.execSQL(MyTable.create_sql);
} @Override
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) { }
}
public class NativeDao { private NativeOpenHelper mHelper; public NativeDao(Context ctx) {
mHelper = new NativeOpenHelper(ctx);
} public void add(String name) {
SQLiteDatabase database = mHelper.getWritableDatabase();
ContentValues values = new ContentValues();
values.put(MyTable.column_name, name);
database.insert(MyTable.name, null, values);
database.close();
}
}
经过加密的数据库
public interface SafeDB { String name = "safe.db";
int version = 1; public interface SafeTable {
String name = "test";
String column_id = "_id";
String column_name = "name";
String create_sql = "create table " + name + "(" + column_id
+ " integer primary key autoincrement, " + column_name
+ " text)";
} }
public class SafeDao { private SafeOpenHelper mHelper; public SafeDao(Context ctx) {
mHelper = new SafeOpenHelper(ctx);
} public void add(String name) {
SQLiteDatabase database = mHelper.getWritableDatabase("123456");
ContentValues values = new ContentValues();
values.put(SafeTable.column_name, name);
database.insert(SafeTable.name, null, values);
database.close();
} public void query() {
SQLiteDatabase database = mHelper.getWritableDatabase("123456");
Cursor cursor = database.query(SafeTable.name,
new String[] { SafeTable.column_name }, null, null, null, null, null); if (cursor != null) {
while (cursor.moveToNext()) {
String name = cursor.getString(0);
System.out.println(name);
} cursor.close();
} database.close();
}
}
import android.content.Context;
import com.loaderman.sqlitedemo.SafeDB.SafeTable; public class SafeDBHelper extends net.sqlcipher.database.SQLiteOpenHelper { public SafeDBHelper(Context ctx) {
super(ctx, SafeDB.name, null, SafeDB.version);
} @Override
public void onCreate(net.sqlcipher.database.SQLiteDatabase db) {
db.execSQL(SafeTable.create_sql);
} @Override
public void onUpgrade(net.sqlcipher.database.SQLiteDatabase arg0, int arg1,
int arg2) { } }
public class MainActivity extends Activity { @Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main); //加载本地库
SQLiteDatabase.loadLibs(this);
} public void normalDB(View view) {
NativeDao dao = new NativeDao(this);
dao.add("hahahhaha");
} public void safeDB(View view) {
SafeDao dao = new SafeDao(this);
dao.add("hehehheheheh");
dao.query();
}
}
发现导出来的数据库文件,一个看到数据,一个看不到数据
数据库开源框架之sqlcipher加密数据库的更多相关文章
- 数据库开源框架GreenDao的使用解析
数据库开源框架GreenDao的使用解析 1,GreenDao概述 1),greenDao是一个当下十分火热的数据库开源框架,或者说是一个帮助Android开发者将数据存到SQLite中的一个开源项目 ...
- 使用SQLCipher加密数据库
Xcode中集成了免费的sqlite,但是不提供加密的模块,突然有一天,蛋疼的客户要求把数据进行加密,于是乎就寻找使用简单并且可以把数据迁移过度到加密数据库的框架. SQLCipher是第三方的开 ...
- Farseer.net轻量级开源框架 中级篇:数据库切换
导航 目 录:Farseer.net轻量级开源框架 目录 上一篇:Farseer.net轻量级开源框架 中级篇: 动态数据库访问 下一篇:Farseer.net轻量级开源框架 中级篇: SQL执行 ...
- Android 轻量级ORM数据库开源框架ActiveAndroid 源码分析
ActiveAndroid 项目地址在https://github.com/pardom/ActiveAndroid 关于他的详细介绍和使用步骤 可以看下面两篇文章: https://github.c ...
- 数据库开源框架之GreenDAO
主页: https://github.com/greenrobot/greenDAO 配置: 添加以下依赖 * compile 'de.greenrobot:greendao:2.1.0' * com ...
- ios开发FMDB导入SQLCipher加密数据库
转:http://www.2cto.com/kf/201407/315727.html [iOS]FMDB/SQLCipher数据库加解密,迁移
- 数据库开源框架ormlite
今天听说了ORM框架ORMLITE,特地去了解了一下. 该框架可以使用注解方式来生成数据库表,还封装了常用的数据库操作. 类似J2EE的HIBERNATE框架对数据库的处理. 省去了书写建表语句的麻烦 ...
- 数据库开源框架之litepal
主页: [https://github.com/LitePalFramework/LitePal](https://github.com/LitePalFramework/LitePal) 中文文档地 ...
- 数据库开源框架之ormlite
主页: http://ormlite.com/ 配置: 添加以下依赖 * compile 'com.j256.ormlite:ormlite-android:4.48' * compile 'com. ...
随机推荐
- shell脚本中的EOF以及文件重定向
<<EOF (内容) EOF 可以把EOF替换成其他东西(分解符) 意思是把内容当作标准输入传给程序 这里再简要回顾一下<<的用法.当Shell看到<<的时 ...
- 快速导入Excel数据到mysql
首先利用mysql文件,导出csv文件, 然后,直接修改csv文件,然后导入csv文件
- 记一次root用户在本地登录及SSH连接均遭遇permission denied的问题排查经过
某日一位老师反映,机房的6号节点无法登录了.一开始以为是为节点防火墙配置IP白名单时忘记了加进去,但随后发现此节点并未进行白名单配置,密码也一直未有变更,于是在自己的电脑上连接,发现终端里很快显示出了 ...
- IPC之sem.c源码解读
// SPDX-License-Identifier: GPL-2.0 /* * linux/ipc/sem.c * Copyright (C) 1992 Krishna Balasubramania ...
- python异常:常见异常、处理、断言、自定义异常
一.异常是什么 二.常见异常 三.异常处理 四.不太常用语法 五.主动判处异常 六.断言 七.使用场景 八.自定义异常类型 一.异常是什么 """ 什么是异常? 异常是错 ...
- Linux基础命令02
常用的一些命令选项 向网络发送icmp检测主机是否在线 ping 指定发送包数量 ping -c windows系统中是ping -t不间断刷包 比如ping百度,ping不同,一直卡在这里,加了-w ...
- Android异常与性能优化相关面试问题-其他优化面试问题详解
Android不用静态变量存储数据: 静态变量等数据由于进程已经被杀死而被初始化.在Android中应用进程不是安全的,因为它会有系统给kill掉,但是在实际中可能会有这样的一个假象:当app被杀掉之 ...
- want
2-SAT POJ3683 操作树 仙人掌 HDU3594 平衡树 916D 可持久化Trie https://www.cnblogs.com/jszkc/p/7309468.html Lindstr ...
- Fastjson转换json到带泛型的对象(如Map)报错解决
List<CategoryDTO> categoryList = null; String categoryStr = redisService.get(RedisKeyConstant. ...
- Oracle之:Function :func_float()
create or replace function func_float(i_value float) return number is v_index number := 0; v_str var ...