android native C++编程实现数据库加密sqlcipher

sqlcipher是sqlite的加版本,分为免费版和收费版。

这里研究的是开源的免费版

https://github.com/sqlcipher/sqlcipher

Android码源默认提供了sqlite的native,jni和java版本,但没有提供sqlcipher,开发用到需要自己添加。

sqlcipher需要配置openssl,写一个android.bp

cpp 复制代码
android_sqlite_cflags = [
    "-DHAVE_USLEEP=1",
    "-DSQLITE_DEFAULT_JOURNAL_SIZE_LIMIT=1048576",
    "-DSQLITE_THREADSAFE=1",
    "-DNDEBUG=1",
    "-DSQLITE_ENABLE_MEMORY_MANAGEMENT=1",
    "-DSQLITE_TEMP_STORE=3",
    "-DSQLITE_ENABLE_FTS3_BACKWARDS",
    "-DSQLITE_ENABLE_LOAD_EXTENSION",
    "-DSQLITE_ENABLE_MEMORY_MANAGEMENT",
    "-DSQLITE_ENABLE_COLUMN_METADATA",
    "-DSQLITE_ENABLE_FTS4",
    "-DSQLITE_ENABLE_UNLOCK_NOTIFY",
    "-DSQLITE_ENABLE_RTREE",
    "-DSQLITE_SOUNDEX",
    "-DSQLITE_ENABLE_STAT3",
    "-DSQLITE_ENABLE_FTS4_UNICODE61",
    "-DSQLITE_THREADSAFE",
    "-Wno-unused-parameter",
    "-Wno-pointer-arith",
    "-Wno-unused-variable"
]

sqlcipher_cflags = [
    "-DSQLITE_HAS_CODEC",
    "-DHAVE_FDATASYNC=0",
    "-Dfdatasync=fsync",
]

sqlcipher_files = ["src/sqlite3.c"]

//APP_STL := c++_shared
//APP_ABI := armeabi-v7a arm64-v8a x86 x86_64
//APP_PLATFORM := android-26

// ANDROIDMK TRANSLATION ERROR: unsupported assignment to LOCAL_EXPORT_C_INCLUDES
// LOCAL_EXPORT_C_INCLUDES := $(LOCAL_PATH)/include/

//LOCAL_SRC_FILES := $(LOCAL_PATH)/lib/arm64-v8a/libcrypto.so
// ANDROIDMK TRANSLATION ERROR: unsupported include
// include $(PREBUILT_SHARED_LIBRARY)
cc_prebuilt_library_shared {
        name: "libcrypto2",
        target: {
            android_arm: {
                srcs: ["lib/armeabi-v7a/libcrypto.so"],
            },
            android_arm64: {
                srcs: ["lib/arm64-v8a/libcrypto.so"],
            },
        },
        strip: {
            none:true,
        },
        //shared_libs: ["libx", "libxx", "libxxx", "libxxxx"],
        check_elf_files: false,
        compile_multilib: "both"//32位和64位都预编译
}

cc_library_shared {
    name: "sqlite3_ext2",
    host_ldlibs: ["-llog"],
    srcs: sqlcipher_files,
    local_include_dirs: [
        "src",
        "include",
    ],
    cflags: android_sqlite_cflags + sqlcipher_cflags,
    //LOCAL_STATIC_LIBRARIES 	:= static-libcrypto
    shared_libs: ["libcrypto2",  "liblog",],

}

详细使用看:

GitHub - blogercn/android_sqlciphe: android natvity C/C++使用的加密数据库sqlciphe

可以用于ndk,可以复制到android源码供C++层开发使用

相关推荐
iAm_Ike12 小时前
c++如何利用std--chrono计算文件操作的微秒级耗时性能分析【详解】
jvm·数据库·python
ErizJ12 小时前
MySQL|腾讯面经总结
数据库·mysql
2401_8800714012 小时前
如何检查SQL注入漏洞覆盖率_使用漏洞管理平台监控
jvm·数据库·python
l1t12 小时前
DeepSeek总结的Delta 成长记:写入、Unity Catalog 和时间旅行
数据库·人工智能·unity
X566112 小时前
Go语言怎么做六边形架构_Go语言六边形架构教程【简明】
jvm·数据库·python
m0_6245785912 小时前
HTML标签不区分大小写吗_标签大小写规范建议【解答】
jvm·数据库·python
CLX050512 小时前
SQL如何计算字符串的长度:LENGTH与CHAR_LENGTH用法
jvm·数据库·python
Frank_refuel12 小时前
C++之STL->string类的使用和实现
java·开发语言·c++
fpcc12 小时前
跟我学C++中级篇—Linux文件读写的分析
linux·c++
2301_7820404512 小时前
mysql如何转换MyISAM表到InnoDB_使用ALTER TABLE语句方法
jvm·数据库·python