Python:加密SQLite3数据库

一、加密SQLite3的库

  • sqleet:(目前)支持到 sqlite3-v3.31.1
  • SQLite3MultipleCiphers:支持到 sqlite3 最新版本

二、编译sqleet及SQLite3MultipleCiphers

2.1)编译 sqleet

cd sqleet
gcc -shared -Wall  -fPIC sqleet.c -lc -lpthread -ldl -o libsqlite3.so

其中 sqleet/libsqlite3.so 就是我们需要的目标文件。

2.2)编译SQLite3MultipleCiphers

# 编译
cd SQLite3MultipleCiphers/
autoreconf
mkdir build-gtk
cd build-gtk
../configure
make

# 创建软连接
cd .libs # SQLite3MultipleCiphers/build-gtk/.libs
ln -s libsqlite3mc.so libsqlite3.so

SQLite3MultipleCiphers/build-gtk/.libs/libsqlite3.so 就是我们需要的目标文件。

三、在 Python 中使用 libsqlite3.so

Python 中自带了 sqlite3,当在 Python 中执行 import sqlite3时,加载的就是默认的 libsqlite3.so。我们需要设置一下 LD_PRELOAD 环境变了,让 Python 在寻找 libsqlite3.so时,首先找到的是我们指定的文件。

下面使用 sqleet 编译出来的 libsqlite3.so 进行演示:

$ LD_PRELOAD=$(pwd)/libsqlite3.so python # 在 shell 中运行 python
Python 3.8.3 (default, Aug 31 2020, 16:03:14) 
[GCC 8.3.1 20191121 (Red Hat 8.3.1-5)] on linux
Type "help", "copyright", "credits" or "license" for more information.
>>> import sqlite3
>>> conn = sqlite3.connect('foo.db') # 创建一个新的数据库,文件名为 foo.db
>>> c = conn.cursor()
>>> c.execute("PRAGMA key='swordfish';") # 输入密码

>>> c.execute('create table foox (id int);') # 创建表

>>> c.close()
>>> conn.commit()
>>> conn.close()
>>> .q

测试一下新创建的加密数据库 foo.db

$ ./sqleet foo.db 
SQLite version 3.31.1 2020-01-27 19:55:54
Enter ".help" for usage hints.
sqlite> .tab
Error: file is not a database   # 没有输入密码,访问失败
sqlite> PRAGMA key='swordfish'; # 输入密码
ok                              # 输出ok,说明密码验证成功
sqlite> .tab                    # 验证密码通过后,访问成功
foox
sqlite> .q

 

你可能感兴趣的:(Python,SQLite,sqlite)