UserMessSqliteDataClass.cs 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268
  1. using CCDCount.MODEL.SqlDataModel;
  2. using System;
  3. using System.Collections.Generic;
  4. using System.Data.SQLite;
  5. using System.IO;
  6. using System.Linq;
  7. using System.Security.Cryptography;
  8. using System.Text;
  9. using System.Threading.Tasks;
  10. namespace CCDCount.DLL.SqlDataClass
  11. {
  12. public class UserMessSqliteDataClass
  13. {
  14. private readonly string _dbPath;
  15. //构建方法,根绝地址初始化数据库
  16. public UserMessSqliteDataClass(string dbPath)
  17. {
  18. _dbPath = dbPath;
  19. // 1. 获取文件夹路径
  20. string directoryPath = Path.GetDirectoryName(dbPath);
  21. // 2. 检查文件夹是否存在
  22. if (!Directory.Exists(directoryPath))
  23. {
  24. // 创建文件夹
  25. Directory.CreateDirectory(directoryPath);
  26. }
  27. InitializeDatabase();
  28. }
  29. // 初始化数据库和表
  30. private void InitializeDatabase()
  31. {
  32. if (!File.Exists(_dbPath))
  33. {
  34. SQLiteConnection.CreateFile(_dbPath);
  35. }
  36. using (var conn = new SQLiteConnection($"Data Source={_dbPath};Version=3;"))
  37. {
  38. conn.Open();
  39. string createTableSql = @"
  40. CREATE TABLE IF NOT EXISTS UserMessage (
  41. Id INTEGER PRIMARY KEY AUTOINCREMENT,
  42. UserName TEXT NOT NULL,
  43. PassWord TEXT NOT NULL,
  44. UserMes TEXT NOT NULL,
  45. DateTime TEXT NOT NULL,
  46. IsDelete INTEGER CHECK (IsDelete IN (0, 1)),
  47. IsAdmin INTEGER CHECK (IsAdmin IN (0, 1))
  48. )";
  49. new SQLiteCommand(createTableSql, conn).ExecuteNonQuery();
  50. }
  51. }
  52. // 插入数据
  53. public int InsertUserMessage(UserMesDataModelClass Message)
  54. {
  55. int result = -1;
  56. if(GetUserMessageForName(Message.UserName).Count>0)
  57. {
  58. result = 2;
  59. return result;
  60. }
  61. using (var conn = new SQLiteConnection($"Data Source={_dbPath};Version=3;"))
  62. {
  63. conn.Open();
  64. string sql = "INSERT INTO UserMessage (UserName, PassWord,UserMes,IsDelete,IsAdmin,DateTime) VALUES (@UserName, @PassWord,@UserMes,@IsDelete,@IsAdmin,@DateTime)";
  65. var cmd = new SQLiteCommand(sql, conn);
  66. cmd.Parameters.AddWithValue("@UserName", Message.UserName);
  67. cmd.Parameters.AddWithValue("@PassWord", HashPassword(Message.PassWord));
  68. cmd.Parameters.AddWithValue("@UserMes", Message.UserMes);
  69. cmd.Parameters.AddWithValue("@IsDelete", Message.IsDelete == true ? 1 : 0);
  70. cmd.Parameters.AddWithValue("@IsAdmin", Message.IsAdmin == true ? 1 : 0);
  71. cmd.Parameters.AddWithValue("@DateTime", Message.DateTime.ToString("yyyy-MM-dd HH:mm:ss.fff")); // 格式化为字符串
  72. cmd.ExecuteNonQuery();
  73. result = 0;
  74. }
  75. return result;
  76. }
  77. // 查询所有数据
  78. public List<UserMesDataModelClass> GetAllUserMessage()
  79. {
  80. var persons = new List<UserMesDataModelClass>();
  81. using (var conn = new SQLiteConnection($"Data Source={_dbPath};Version=3;"))
  82. {
  83. conn.Open();
  84. string sql = "SELECT * FROM UserMessage WHERE IsDelete=0";
  85. var cmd = new SQLiteCommand(sql, conn);
  86. using (SQLiteDataReader reader = cmd.ExecuteReader())
  87. {
  88. while (reader.Read())
  89. {
  90. persons.Add(new UserMesDataModelClass
  91. {
  92. Id = Convert.ToInt32(reader["Id"]),
  93. UserName = reader["UserName"].ToString(),
  94. PassWord = reader["PassWord"].ToString(),
  95. UserMes = reader["UserMes"].ToString(),
  96. // 解析时间字符串
  97. DateTime = DateTime.Parse(reader["DateTime"].ToString()),
  98. IsAdmin = Convert.ToInt32(reader["IsAdmin"]) == 1 ? true : false,
  99. IsDelete = Convert.ToInt32(reader["IsDelete"]) == 1 ? true : false
  100. });
  101. }
  102. }
  103. }
  104. return persons;
  105. }
  106. // 查询对应用户名的所有信息
  107. public List<UserMesDataModelClass> GetUserMessageForName(string UserName)
  108. {
  109. var persons = new List<UserMesDataModelClass>();
  110. using (var conn = new SQLiteConnection($"Data Source={_dbPath};Version=3;"))
  111. {
  112. conn.Open();
  113. string sql = "SELECT * FROM UserMessage WHERE UserName = @UserName AND IsDelete = 0";
  114. var cmd = new SQLiteCommand(sql, conn);
  115. cmd.Parameters.AddWithValue("@UserName", UserName);
  116. using (SQLiteDataReader reader = cmd.ExecuteReader())
  117. {
  118. while (reader.Read())
  119. {
  120. persons.Add(new UserMesDataModelClass
  121. {
  122. Id = Convert.ToInt32(reader["Id"]),
  123. UserName = reader["UserName"].ToString(),
  124. PassWord = reader["PassWord"].ToString(),
  125. UserMes = reader["UserMes"].ToString(),
  126. // 解析时间字符串
  127. DateTime = DateTime.Parse(reader["DateTime"].ToString()),
  128. IsAdmin = Convert.ToInt32(reader["IsAdmin"]) == 1 ? true : false,
  129. IsDelete = Convert.ToInt32(reader["IsDelete"]) == 1 ? true : false
  130. });
  131. }
  132. }
  133. }
  134. return persons;
  135. }
  136. // 查询对应用户ID的所有信息
  137. public List<UserMesDataModelClass> GetUserMessageForId(int Id)
  138. {
  139. var persons = new List<UserMesDataModelClass>();
  140. using (var conn = new SQLiteConnection($"Data Source={_dbPath};Version=3;"))
  141. {
  142. conn.Open();
  143. string sql = "SELECT * FROM UserMessage WHERE Id = @Id AND IsDelete = 0";
  144. var cmd = new SQLiteCommand(sql, conn);
  145. cmd.Parameters.AddWithValue("@Id", Id);
  146. using (SQLiteDataReader reader = cmd.ExecuteReader())
  147. {
  148. while (reader.Read())
  149. {
  150. persons.Add(new UserMesDataModelClass
  151. {
  152. Id = Convert.ToInt32(reader["Id"]),
  153. UserName = reader["UserName"].ToString(),
  154. PassWord = reader["PassWord"].ToString(),
  155. UserMes = reader["UserMes"].ToString(),
  156. // 解析时间字符串
  157. DateTime = DateTime.Parse(reader["DateTime"].ToString()),
  158. IsAdmin = Convert.ToInt32(reader["IsAdmin"]) == 1 ? true : false,
  159. IsDelete = Convert.ToInt32(reader["IsDelete"]) == 1 ? true : false
  160. });
  161. }
  162. }
  163. }
  164. return persons;
  165. }
  166. //查询用户名的登录信息是否正确
  167. public bool CheckUserLogin(string UserName, string PassWord)
  168. {
  169. return GetAllUserMessage().Any(x => x.UserName == UserName && x.PassWord == HashPassword(PassWord));
  170. }
  171. //修改密码(使用ID)
  172. public bool ChangePassWord(int Id, string OldPassWord, string NewPassWord)
  173. {
  174. bool result = false;
  175. using (var conn = new SQLiteConnection($"Data Source={_dbPath};Version=3;"))
  176. {
  177. conn.Open();
  178. string sql = "UPDATE UserMessage SET PassWord = @PassWord WHERE Id = @Id AND IsDelete = 0";
  179. var cmd = new SQLiteCommand(sql, conn);
  180. cmd.Parameters.AddWithValue("@PassWord", HashPassword(NewPassWord));
  181. cmd.Parameters.AddWithValue("@Id", Id);
  182. cmd.ExecuteNonQuery();
  183. result = true;
  184. }
  185. return result;
  186. }
  187. public bool ChangeUserMessage(int Id,UserMesDataModelClass Message)
  188. {
  189. bool result = false;
  190. using (var conn = new SQLiteConnection($"Data Source={_dbPath};Version=3;"))
  191. {
  192. conn.Open();
  193. string sql = "UPDATE UserMessage SET UserName = @UserName,PassWord = @PassWord,UserMes = @UserMes,IsAdmin = @IsAdmin WHERE Id = @Id AND IsDelete = 0";
  194. var cmd = new SQLiteCommand(sql, conn);
  195. cmd.Parameters.AddWithValue("@UserName", Message.UserName);
  196. cmd.Parameters.AddWithValue("@PassWord", HashPassword(Message.PassWord));
  197. cmd.Parameters.AddWithValue("@UserMes", Message.UserMes);
  198. cmd.Parameters.AddWithValue("@Id", Id);
  199. cmd.Parameters.AddWithValue("@IsAdmin", Message.IsAdmin);
  200. cmd.ExecuteNonQuery();
  201. result = true;
  202. }
  203. return result;
  204. }
  205. // 重置密码
  206. public bool ResetPassWord(int Id)
  207. {
  208. bool result = false;
  209. using (var conn = new SQLiteConnection($"Data Source={_dbPath};Version=3;"))
  210. {
  211. conn.Open();
  212. string sql = "UPDATE UserMessage SET PassWord = @PassWord WHERE Id = @Id AND IsDelete = 0";
  213. var cmd = new SQLiteCommand(sql, conn);
  214. cmd.Parameters.AddWithValue("@PassWord", HashPassword("123456"));
  215. cmd.Parameters.AddWithValue("@Id", Id);
  216. cmd.ExecuteNonQuery();
  217. result = true;
  218. }
  219. return result;
  220. }
  221. // 删除用户信息
  222. public bool DeleteUserMessage(int Id)
  223. {
  224. bool result = false;
  225. using (var conn = new SQLiteConnection($"Data Source={_dbPath};Version=3;"))
  226. {
  227. conn.Open();
  228. string sql = "UPDATE UserMessage SET IsDelete = 1 WHERE Id = @Id";
  229. var cmd = new SQLiteCommand(sql, conn);
  230. cmd.Parameters.AddWithValue("@Id", Id);
  231. cmd.ExecuteNonQuery();
  232. result = true;
  233. }
  234. return result;
  235. }
  236. // Hash密码加密
  237. public string HashPassword(string password)
  238. {
  239. using (SHA256 sha256 = SHA256.Create())
  240. {
  241. byte[] bytes = sha256.ComputeHash(Encoding.UTF8.GetBytes(password));
  242. StringBuilder builder = new StringBuilder();
  243. for (int i = 0; i < bytes.Length; i++)
  244. {
  245. builder.Append(bytes[i].ToString("x2"));
  246. }
  247. return builder.ToString();
  248. }
  249. }
  250. }
  251. }