赞
踩
sqlite官方的数据库加密是收费的,而且比较贵。
幸亏微软提供了一种免费的方法。
这里我做了一个小的demo演示如下:
在界面中拖入数据库名、密码、以及保存的路径
比如我选择保存路径桌面的sqlite目录,数据库名guigutool.db,密码1234
点创建数据库。
我们在桌面文件夹sqlite看到guigutool.db
然后向其中插入
Microsoft.Data.Sqlite.Core
SQLitePCLRaw.bundle_e_sqlcipher
Dapper
在Form中拖入控件这里就省略了。
static SqliteConnection conn = null;
private void getConn()
{
string dbpath = txt_path.Text;
string dbname = txt_dbname.Text;
string pwd = txt_pwd.Text;
string dbpathConn = Path.Combine(@"Data Source=" + dbpath, dbname);
string connString = new SqliteConnectionStringBuilder(dbpathConn)
{
Mode = SqliteOpenMode.ReadWriteCreate,
Password = pwd
}.ToString();
if (conn != null)
{
conn.Dispose();
}
conn = new SqliteConnection(connString);
}
创建数据库时,会自动创建一个测试表User
private void btn_createdb_Click(object sender, EventArgs e)
{
if (String.IsNullOrEmpty(txt_dbname.Text) || String.IsNullOrEmpty(txt_pwd.Text))
{
MessageBox.Show("请输入数据库名和密码");
return;
}
string dbFullPath = Path.Combine(txt_path.Text, txt_dbname.Text);
ShowInfo(txtInfo, dbFullPath);
if (File.Exists(dbFullPath))
{
MessageBox.Show("该数据库已存在,不能创建");
return;
}
getConn();
if (conn.State == System.Data.ConnectionState.Closed)
{
conn.Open();
var createTable = @"CREATE table if not exists ""User"" (""Id"" INTEGER PRIMARY KEY AUTOINCREMENT NOT NULL,""name"" TEXT,""age"" INTEGER);";
var result = conn.Execute(createTable);
conn.Close();
ShowInfo(txtInfo, "数据库:" + this.txt_path.Text + txt_dbname.Text + "已创建成功,并插入了测试表User");
}
}
private void btn_insert_Click(object sender, EventArgs e)
{
getConn();
if (conn.State == System.Data.ConnectionState.Closed)
{
conn.Open();
var name = GenerateSurname();
var age = GenerateAge();
var insertSql = $@"INSERT INTO ""main"".""User""(name,age) VALUES (""{name}"", {age});";
int result = conn.Execute(insertSql);
conn.Close();
ShowInfo(txtInfo, $"插入记录成功==> Name:{name} Age:{age} ");
}
}
private void btn_query_Click(object sender, EventArgs e)
{
getConn();
if (conn.State == System.Data.ConnectionState.Closed)
{
conn.Open();
var name = GenerateSurname();
var age = GenerateAge();
var selectSql = "select id,name,age from main.User;";
var users = conn.Query<User>(selectSql).ToList();
ShowInfo(txtInfo, $"================ 查询db[{txt_dbname.Text}]到以下记录:===================");
foreach (var user in users)
{
ShowInfo(txtInfo, $"Id:{user.Id} Name:{user.Name} Age:{user.Age} ");
}
ShowInfo(txtInfo, $"=============== 共{users.Count} 条 ================");
conn.Close();
}
}
以上就是主要的代码。
项目的完整代码可以在以下资源中下载。
https://download.csdn.net/download/wang6733284/87503163
将Navicat目录下创建一个备份文件夹sqlite3_bak, 然后将sqlite3.dll文件(大约910KB)移动到备份文件夹中。
将e_sqlcipher.dll(1763KB)包拷贝到navicat 目录下,重命名为sqlite3.dll
然后在navicat中新建SQLite连接。
这里选择我们在桌面创建的guitutool.db文件。
(这里下的连接测试,无论是否加密,都会显示连接成功的,但是实际打开数据库时,如果不输入密码会提示错误。)
然后选择高级,在这里输入密码。
这时候连接,就可以打开了。
比如我手工通过navicat添加一条记录。
然后再选择Sqlite工具箱查询:
即可查询到。
总结一下
使用e_sqlcipher.dll替代sqlite3.dll,可以通过navicat来方便数据的管理。
e_sqlcipher.dll文件在我们的源程序的Debug目录下,大小月1763KB,具体参考下面。
SqliteBox\bin\Debug\net7.0-windows\runtimes\win-x64\native\
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。