QtSqlite加密--QtCipherSqlitePlugin的使用

QtSqlite加密

上次说了QxOrm的数据库连接、映射和基础的增删改查,但是我们在使用数据库的时候并不希望别人看到我们数据库的内容,我们希望我们的数据库是能被加密的,只有我们用正确的密码才能连接上我们的数据库。加密之后就可以对数据安全作出一定的保障。

sqlite官方带加密版本的是要收费的,这个时候就不得不推荐一个项目

该项目是一个QT的加密Sqlite数据库的插件,编译特别简单,直接使用QtCreator打开编译即可。所以不介绍编译了,直接介绍该插件的使用吧。

第一步:环境准备

虽然没有介绍编译,但是我们编译出来的库是需要拷贝到Qt安装目录下的

将sqlitecipher.dll 和 sqlitecipherd.dll 拷贝到安装目录下的$path$\5.15.2\msvc2019_64\plugins\sqldrivers文件夹下,之后我们就可以正常使用该方式创建sqlite数据库了。

第二步:连接数据库

我们之前直接使用的时候是直接使用QSQLITE去连接的,这里我们使用新的SQLITECIPHER类型,在此之前你可以先使用 QSqlDatabase::drivers() 查看是否支持,如果不支持,请重新进行环境准备步骤

我这里输出的是 QSQLITE QODBC QODBC3 QPSQL QPSQL7 SQLITECIPHER

void databaseInit()
{
    for(const auto &a : QSqlDatabase::drivers())
    {
        std::cout << a.toStdString() << " ";
    }
    std::cout << std::endl;
    
    qx::QxSqlDatabase::getSingleton()->setDriverName("SQLITECIPHER");
    qx::QxSqlDatabase::getSingleton()->setDatabaseName("./demo.db");
    qx::QxSqlDatabase::getSingleton()->setPassword("1234");
}

这里应该直接看函数名称就可以看懂,不需要进行详细的解释。

第三步:数据库操作

像之前一样直接进行数据操作,这里不做详细介绍。增删改查就可以。

我贴出代码,你们自己测试即可

#include <QApplication>
#include <QApplication>
#include "precompiled.h"
#include "person.h"
#include "author.h"
#include "author2.h"
#include "turbo_log.h"

void databaseInit()
{
    for(const auto &a : QSqlDatabase::drivers())
    {
        std::cout << a.toStdString() << " ";
    }
    std::cout << std::endl;
    qx::QxSqlDatabase::getSingleton()->setDriverName("SQLITECIPHER");
    qx::QxSqlDatabase::getSingleton()->setDatabaseName("./demo.db");
    qx::QxSqlDatabase::getSingleton()->setPassword("1234");
}

void createTable()
{
    QSqlError daoError = qx::dao::create_table<person>();
    if (daoError.type() != QSqlError::NoError)
    {
        TurboLog::instance().getConsoleLogger()->error("Table person:" + daoError.text().toStdString());
    }
    daoError = qx::dao::create_table<author>();
    if (daoError.type() != QSqlError::NoError)
    {
        TurboLog::instance().getConsoleLogger()->error("Table author:" + daoError.text().toStdString());
    }
    daoError = qx::dao::create_table<author2>();
    if (daoError.type() != QSqlError::NoError)
    {
        TurboLog::instance().getConsoleLogger()->error("Table author2:" + daoError.text().toStdString());
    }
}

void insertData()
{
    person p;
    p.firstName = "王五";
    p.lastName = "王五2";
    p.birthDate = QDateTime::fromString("1996-04-25", "yyyy-MM-dd");
    p.age = 23;
    QSqlError daoError =  qx::dao::insert(p);
    daoError =  qx::dao::insert(p);
    daoError =  qx::dao::insert(p);
    daoError =  qx::dao::insert(p);
    daoError =  qx::dao::insert(p);
    if (daoError.type() != QSqlError::NoError)
    {
        TurboLog::instance().getConsoleLogger()->error("insert update:" + daoError.text().toStdString());
    }
}

void selectData()
{
    QList<person> persons;
    qx::dao::fetch_all(persons);
    TurboLog::instance().getConsoleLogger()->error("select table:{}", persons.size());
}

void deleteData()
{
//    person p;
//    qx_query query;
//    query.where("id").isEqualTo(2);
    QSqlError daoError =  qx::dao::destroy_all<person>();
    if (daoError.type() != QSqlError::NoError)
    {
        TurboLog::instance().getConsoleLogger()->error("delete persons:" + daoError.text().toStdString());
    }
//    qx_query query2;
//    query2.where("id").isEqualTo(1);
//    daoError =  qx::dao::destroy_by_query<person>(query2);
//    if (daoError.type() != QSqlError::NoError)
//    {
//        TurboLog::instance().getConsoleLogger()->error("delete persons:" + daoError.text().toStdString());
//    }
}
int main(int argc, char **argv)
{
    QApplication app(argc, argv);
    databaseInit();
    insertData();
//    selectData();
    // deleteData();
    return app.exec();
}

第四步:使用新的可视化工具查看数据库数据

这里我们再使用DBeaver查看数据库的时候已经无法查看了,因此我们需要使用新的软件去查看数据库。

推荐软件:

该软件是开源的QT写的数据库查看工具,操作起来像Navicate(个人感觉),因此上手不难。我们就介绍如何连接到我们加密好的数据库吧。

在这里插入图片描述

如上图所示,我们先点击数据库 → \rightarrow 然后点击添加数据库 → \rightarrow 到数据类型我们选择WxSqlite3 → \rightarrow 选择数据库,输入密码 → \rightarrow 加密算法选择sqlsheet那个 → \rightarrow 点击测试连接(如果通过则显示一个对号) → \rightarrow 输入sql语句进行数据查询。

  • 1
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 7
    评论
### 回答1: Linux QtSqlite加密是指在Linux系统上使用QtSqlite库对数据库进行加密处理的过程。QtSqlite是基于SQLite的C++库,用于在Qt框架下操作数据库SQLite是一种轻型、嵌入式的数据库引擎,广泛用于各种应用程序的数据存储和管理。 要在Linux上使用QtSqlite加密功能,可以借助Qt提供的QtCipherSqlitePlugin插件。QtCipherSqlitePlugin是一个用于对SQLite数据库进行加密和解密的插件,它可以在数据库打开和关闭的过程中对数据进行加密和解密操作,保护数据库的机密性。 使用QtCipherSqlitePlugin进行加密时,先需要在Qt应用程序中加载该插件,并将其注册到数据库驱动中。然后,可以通过设置数据库加密密钥和算法类型来指定加密方式。常见的加密算法包括AES和DES等。 加密后的数据库文件在存储和传输过程中更加安全,无法直接被读取和修改。在使用数据库时,需要提供正确的密钥才能解密数据进行操作。而没有密钥的人则无法对数据库进行读写操作,保证了数据的机密性和安全性。 总而言之,Linux QtSqlite加密QtCipherSqlitePlugin使用可以有效保护数据库的安全。通过对数据库进行加密处理,可以防止敏感数据的泄漏和篡改,为应用程序和用户提供更高的数据安全保障。 ### 回答2: Linux QtSQLITE加密是指在Linux操作系统中使用QtSQLITE库进行数据库操作时,对数据库进行加密的过程。QtSQLITE是一个用于在Qt应用程序中访问和操作SQLite数据库的插件。 QtCipherSQLitePlugin是一个在Qt应用程序中使用SQLite数据库加密插件。它提供了一种轻松而安全的方法来对SQLite数据库进行加密和解密操作。使用QtCipherSQLitePlugin,我们可以通过在连接到数据库之前设置加密密钥来保护数据库中的数据。这样,即使数据库文件被非法访问,也无法获取到其中的明文数据。 要使用QtCipherSQLitePlugin,首先需要在项目中添加相应的插件文件,并在代码中进行相关设置。然后,我们可以在代码中使用QtSQLITE库提供的API进行数据库操作,如创建表、插入数据、查询数据等。在连接到数据库之前,我们可以通过使用QtCipherSQLitePlugin提供的接口设置加密密钥,以保护数据库中的数据。 使用Linux QtSQLITE加密QtCipherSQLitePlugin可以有效地保护数据库中的敏感数据。通过加密数据库,即使数据库文件被非法获取,也无法直接获取到其中的明文数据。这样可以提高数据的安全性,并保护用户的隐私。 总结来说,Linux QtSQLITE加密QtCipherSQLitePlugin是一种用于在Linux操作系统中使用QtSQLITE库对SQLite数据库进行加密的解决方案。它提供了一种简单而安全的方法来保护数据库的数据,加强数据的安全性。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 7
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

turbolove

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值