SQLite加密程序

1.前言

最近做一个项目使用到SQLite数据库,但免费版的没有加密功能,手写一个加密程序,解密将新密码设置为空即可

2.效果

 

3.相关代码

using System;
using System.Collections.Generic;
//using System.Linq;
using System.Text;
//using System.Configuration;
using System.Data;
using System.IO;
using System.Data.SQLite;

namespace SQLiteEncryptionPro
{
    public static class SQLiteHelper
    {
        //SQLiteHelper.ConStr = "Data Source="+Application.StartupPath+"\\SQLiteDemo;Pooling=true;FaillfMissing=false";
        //private string connString="Server=.;Database=TemperatureDB;Uid=sa;Pwd=luozhiwei"
        //private static string ConStr = System.Configuration.ConfigurationManager.ConnectionStrings["ConStr"].ToString();
        public static string ConStr = "";
        //<connectionStrings>
        //<add name="connString" connectionString="Data Source=.;Initial Catalog=SMDB;Persist Security Info=True;User ID=sa;Password=luozhiwei"/>
        //</connectionStrings>

        #region 执行格式化的SQL语句
        /// <summary>
        /// 执行增删改
        /// </summary>
        /// <param name="sql"><
        /// ram>
        /// <returns></returns>
        public static int Update(string sql)
        {
            SQLiteConnection DBConnection = new SQLiteConnection(ConStr);
            SQLiteCommand cmd = new SQLiteCommand(sql, DBConnection);
            try
            {
                DBConnection.Open();
                return cmd.ExecuteNonQuery();
            }
            catch (Exception ex)
            {
                throw ex;
            }
            finally
            {
                DBConnection.Close();
            }
        }
        /// <summary>
        /// SQLite数据库设置密码
        /// </summary>
        /// <param name="sql"></param>
        /// <returns></returns>
        public static void SetPassword(string pwd)
        {
            SQLiteConnection DBConnection = new SQLiteConnection(ConStr);            
            DBConnection.Open();
            DBConnection.ChangePassword(pwd);
            //DBConnection.Close();
        }

        public static void SetPasswordFirst(string pwd)
        {
            SQLiteConnection DBConnection = new SQLiteConnection(ConStr);
            
            DBConnection.SetPassword(pwd);
            DBConnection.Open();
            //DBConnection.Close();
        }
        /// <summary>
        /// 获取单一结果
        /// </summary>
        /// <param name="sql"></param>
        /// <returns></returns>
        public static object GetSingleResult(string sql)
        {
            SQLiteConnection DBConnection = new SQLiteConnection(ConStr);
            SQLiteCommand cmd = new SQLiteCommand(sql, DBConnection);
            try
            {
                DBConnection.Open();
                return cmd.ExecuteScalar();
            }
            catch (Exception ex)
            {

                throw ex;
            }
            finally
            {
                DBConnection.Close();
            }
        }
        /// <summary>
        /// 返回结果集
        /// </summary>
        /// <param name="sql"></param>
        /// <returns></returns>
        public static SQLiteDataReader GetReader(string sql)
        {
            SQLiteConnection DBConnection = new SQLiteConnection(ConStr);
            SQLiteCommand cmd = new SQLiteCommand(sql, DBConnection);
            try
            {
                DBConnection.Open();
                return cmd.ExecuteReader(CommandBehavior.CloseConnection);
            }
            catch (Exception ex)
            {
                DBConnection.Close();
                throw ex;
            }


        }
        /// <summary>
        /// 返回数据集
        /// </summary>
        /// <param name="sql"></param>
        /// <returns></returns>
        public static DataSet GetDataSet(string sql, SQLiteParameter[] param=null)
        {
            SQLiteConnection DBConnection = new SQLiteConnection(ConStr);
            SQLiteCommand cmd = new SQLiteCommand(sql, DBConnection);
            SQLiteDataAdapter da = new SQLiteDataAdapter(cmd);
            DataSet ds = new DataSet();
            try
            {
                DBConnection.Open();
                if (param!=null)
                {
                    cmd.Parameters.AddRange(param);//添加参数
                }
                da.Fill(ds);
                return ds;
            }
            catch (Exception)
            {
                return null;
            }
            finally
            {
                DBConnection.Close();
            }
        }
        #endregion

        #region 启用事务执行多条SQL语句
        /// <summary>
        /// 启用事务执行多条SQL语句
        /// </summary>
        /// <param name="sqlList"></param>
        /// <returns></returns>
        public static bool UpdateByTran(List<string> sqlList)
        {
            SQLiteConnection DBConnection = new SQLiteConnection(ConStr);
            SQLiteCommand cmd = new SQLiteCommand();
            cmd.Connection = DBConnection;
            try
            {
                DBConnection.Open();
                cmd.Transaction = DBConnection.BeginTransaction();//开启事务
                foreach (string itemsql in sqlList)
                {
                    cmd.CommandText = itemsql;
                    cmd.ExecuteNonQuery();
                }
                cmd.Transaction.Commit();//提交事务
                return true;
            }
            catch (Exception ex)
            {
                if (cmd.Transaction != null)
                    cmd.Transaction.Rollback();//回滚事务(前面提交了,但是没有正常更新)
                throw new Exception("调用事务方法时出现错误:" + ex.Message);
            }
            finally
            {
                if (cmd.Transaction != null)
                    cmd.Transaction = null;//清空事务
                DBConnection.Close();

            }
        }
        #endregion

        #region 错误信息写入日志
        /// <summary>
        /// 将错误信息写入日志文件
        /// </summary>
        /// <param name="msg"></param>
        private static void WriteLog(string msg)
        {
            FileStream fs = new FileStream("Log.text", FileMode.Append);
            StreamWriter sw = new StreamWriter(fs);
            sw.WriteLine("[{0}]  错误信息:{1}", DateTime.Now.ToString(), msg);
            sw.Close();
            fs.Close();
        }
        #endregion

        #region 执行带参数的SQL语句
        /// <summary>
        /// 执行增删改
        /// </summary>
        /// <param name="sql"></param>
        /// <returns></returns>
        public static int Update(string sql, SQLiteParameter[] param)
        {
            SQLiteConnection DBConnection = new SQLiteConnection(ConStr);
            SQLiteCommand cmd = new SQLiteCommand(sql, DBConnection);

            try
            {

                DBConnection.Open();
                cmd.Parameters.AddRange(param);//添加参数
                return cmd.ExecuteNonQuery();
            }
            catch (Exception ex)
            {
                WriteLog("执行Update(string sql)方法发生错误,错误日志:" + ex.Message);
                throw;
            }
            finally
            {
                DBConnection.Close();
            }
        }
        /// <summary>
        /// 返回单一结果
        /// </summary>
        /// <param name="sql"></param>
        /// <returns></returns>
        public static object GetSingleResult(string sql, SQLiteParameter[] param)
        {
            SQLiteConnection DBConnection = new SQLiteConnection(ConStr);
            SQLiteCommand cmd = new SQLiteCommand(sql, DBConnection);
            if (param != null)
            {
                cmd.Parameters.AddRange(param);//添加参数
            }
            try
            {
                DBConnection.Open();
                return cmd.ExecuteScalar();
            }
            catch (Exception ex)
            {
                WriteLog("执行GetSingleResult(string sql)方法发生错误,错误日志:" + ex.Message);
                throw;
            }
            finally
            {
                DBConnection.Close();
            }
        }
        /// <summary>
        /// 返回数据集
        /// </summary>
        /// <param name="sql"></param>
        /// <returns></returns>
        public static SQLiteDataReader GetReader(string sql, SQLiteParameter[] param)
        {
            SQLiteConnection DBConnection = new SQLiteConnection(ConStr);
            SQLiteCommand cmd = new SQLiteCommand(sql, DBConnection);
            try
            {
                DBConnection.Open();
                cmd.Parameters.AddRange(param);
                return cmd.ExecuteReader(CommandBehavior.CloseConnection);
            }
            catch (Exception ex)
            {
                WriteLog("执行GetReader(string sql)方法发生错误,错误日志:" + ex.Message);
                DBConnection.Close();
                throw ex;
            }

        }
        /// <summary>
        /// 获取数据库服务器时间
        /// </summary>
        /// <returns></returns>
        public static DateTime GetDBServerTime()
        {
            string sql = "select getdate()";
            return Convert.ToDateTime(GetSingleResult(sql, null));
        }
        #endregion

        #region 调用存储过程
        /// <summary>
        /// 基于存储过程的Update
        /// </summary>
        /// <param name="storeProcedureName"></param>
        /// <param name="param"></param>
        /// <returns></returns>
        public static int UpdateByProcedureName(string storeProcedureName, SQLiteParameter[] param)
        {
            SQLiteConnection DBConnection = new SQLiteConnection(ConStr);
            SQLiteCommand cmd = new SQLiteCommand();
            cmd.Connection = DBConnection;
            cmd.CommandType = CommandType.StoredProcedure;//当前执行的是存储过程
            cmd.CommandText = storeProcedureName;
            try
            {
                DBConnection.Open();
                cmd.Parameters.AddRange(param);//添加参数
                return cmd.ExecuteNonQuery();
            }
            catch (Exception ex)
            {
                WriteLog("执行UpdateByProcedureName(string storeProcedureName, SQLiteParameter[] param)方法发生错误,错误日志:" + ex.Message);
                throw ex;
            }
            finally
            {
                DBConnection.Close();
            }
        }
        /// <summary>
        /// 基于存储过程的查询,返回结果集
        /// </summary>
        /// <param name="sql"></param>
        /// <param name="param"></param>
        /// <returns></returns>
        public static SQLiteDataReader GetReaderByProcedure(string storeProcedureName, SQLiteParameter[] param)
        {
            SQLiteConnection DBConnection = new SQLiteConnection(ConStr);
            SQLiteCommand cmd = new SQLiteCommand();
            cmd.Connection = DBConnection;
            cmd.CommandType = CommandType.StoredProcedure;//当前执行的是存储过程
            cmd.CommandText = storeProcedureName;
            try
            {
                DBConnection.Open();
                if (param!=null)
                {
                    cmd.Parameters.AddRange(param);
                }
                return cmd.ExecuteReader(CommandBehavior.CloseConnection);
            }
            catch (Exception ex)
            {
                WriteLog("执行GetReaderByProcedure(string storeProcedureName, SQLiteParameter[] param)方法发生错误,错误日志:" + ex.Message);
                DBConnection.Close();
                throw ex;
            }

        }
        /// <summary>
        /// 基于存储过程,返回数据集
        /// </summary>
        /// <param name="sql"></param>
        /// <returns></returns>
        public static DataSet GetDataSetByProcedure(string storeProcedureName, SQLiteParameter[] param)
        {
            SQLiteConnection DBConnection = new SQLiteConnection(ConStr);
            SQLiteCommand cmd = new SQLiteCommand(storeProcedureName, DBConnection);
            cmd.CommandType = CommandType.StoredProcedure;
            SQLiteDataAdapter da = new SQLiteDataAdapter(cmd);
            DataSet ds = new DataSet();
            try
            {
                DBConnection.Open();
                if (param!=null)
                {
                    cmd.Parameters.AddRange(param);
                }
                da.Fill(ds);
                return ds;
            }
            catch (Exception)
            {
                return null;
            }
            finally
            {
                DBConnection.Close();
            }
        }
        #endregion
    }
}

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 4
    评论
### 回答1: MFC(Microsoft Foundation Class)是一组用于开发Windows应用程序的类库,而SQLite是一种轻型的嵌入式数据库引擎。在MFC中使用SQLite加密的过程主要包括以下几个步骤: 1. 在MFC应用程序中引入SQLite的相关文件和头文件。可以通过下载SQLite的最新版本,将相关的库文件和头文件添加到MFC项目中。 2. 创建SQLite数据库并打开连接。在MFC应用程序中可以使用SQLite提供的API来创建和打开数据库连接。可以通过调用sqlite3_open函数指定一个数据库文件名来创建和打开数据库连接。 3. 在数据库中创建表和字段。可以使用SQLite提供的API来创建表和定义字段,以存储和检索数据。可以使用SQL语句来创建表和字段,如CREATE TABLE和ALTER TABLE等。 4. 加密数据库。在SQLite中,可以通过设置密码来对数据库进行加密。可以使用sqlite3_key函数来设置数据库密码,并使用sqlite3_rekey函数来修改或移除密码。在使用密码对数据库进行加密后,需要在每次打开数据库连接时先调用sqlite3_key函数以提供正确的密码。 5. 对数据库进行操作。在MFC应用程序中可以使用SQLite提供的API对数据库进行插入、更新和删除等操作。可以使用SQL语句来执行各种操作,如INSERT、UPDATE和DELETE等。 6. 关闭数据库连接。在MFC应用程序中,需要在使用完数据库后调用sqlite3_close函数来关闭数据库连接,释放相关资源。 综上所述,MFC中使用SQLite加密的过程包括引入SQLite文件和头文件、创建数据库和表、加密数据库、对数据库进行操作以及关闭数据库连接等步骤。通过这些步骤,可以在MFC应用程序中实现对SQLite数据库的加密和使用。 ### 回答2: MFC(Microsoft Foundation Classes)是一个用于开发Windows应用程序的C++类库。SQLite是一种嵌入式数据库管理系统。要在MFC中使用SQLite数据库进行加密,可以按照以下步骤进行操作。 首先,需要确保你的MFC项目中已经正确地集成了SQLite数据库。你可以通过添加SQLite的头文件和链接SQLite的库文件来实现。 其次,为了在MFC中对SQLite数据库进行加密,可以使用SQLite提供的加密扩展库,如SQLCipher。SQLCipher使用密钥对数据库进行加密和解密操作。 要使用SQLCipher进行加密,需要下载SQLCipher的预编译库,并将其添加到MFC项目中。然后,将相关的头文件引入项目。 接下来,在MFC项目中的数据库连接代码中,需要调用SQLCipher提供的函数来打开加密数据库。首先,你需要提供一个密钥,然后调用相应的函数来打开数据库。使用SQLCipher函数将密钥传递给数据库,以实现加密。 一旦数据库已经被加密,你就可以像使用普通的SQLite数据库一样使用它。可以执行查询、插入、更新和删除操作。 需要注意的是,在打开加密数据库之前,你需要确保已经安装了适用于你的操作系统的SQLCipher库。 总之,要在MFC中对SQLite数据库进行加密,首先需要集成SQLite和SQLCipher的库文件和头文件到MFC项目中。然后,使用SQLCipher函数调用来打开加密数据库,并提供相应的密钥。在此之后,就可以像使用普通SQLite数据库一样使用加密数据库。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值