(资料图)
假设有User表
public class User : Entity{ public int Id { get; set; } public string UserName { get; set; } public string Name { get; set; } public string IdentificationNumber { get; set; }}
其中有身份证号码IdentificationNumber列,需要加密存储,该如何实现? : base( x => Encrypt(x), x => Decrypt(x)) { DefaultPassPhrase = "gsKnGZ041HLL4IM8"; DefaultInitVectorBytes = Encoding.ASCII.GetBytes("jkE49230Tf093b42"); DefaultSalt = Encoding.ASCII.GetBytes("hgt!16kl"); } private static string Encrypt(TModel input) { try { byte[] inputData = input switch { string => Encoding.UTF8.GetBytes(input.ToString()), byte[] => input as byte[], _ => null, }; using (var password = new Rfc2898DeriveBytes(DefaultPassPhrase, DefaultSalt)) { var keyBytes = password.GetBytes(DefaultKeysize / 8); using (var symmetricKey = Aes.Create()) { symmetricKey.Mode = CipherMode.CBC; using (var encryptor = symmetricKey.CreateEncryptor(keyBytes, DefaultInitVectorBytes)) { using (var memoryStream = new MemoryStream()) { using (var cryptoStream = new CryptoStream(memoryStream, encryptor, CryptoStreamMode.Write)) { cryptoStream.Write(inputData, 0, inputData.Length); cryptoStream.FlushFinalBlock(); var cipherTextBytes = memoryStream.ToArray(); var rawString = Convert.ToBase64String(cipherTextBytes); return rawString; } } } } } } catch (Exception ex) { LogHelper.LogException(ex); return input.ToString(); } } private static TModel Decrypt(string input) { try { var cipherTextBytes = Convert.FromBase64String(input); using (var password = new Rfc2898DeriveBytes(DefaultPassPhrase, DefaultSalt)) { var keyBytes = password.GetBytes(DefaultKeysize / 8); using (var symmetricKey = Aes.Create()) { symmetricKey.Mode = CipherMode.CBC; using (var decryptor = symmetricKey.CreateDecryptor(keyBytes, DefaultInitVectorBytes)) { using (var memoryStream = new MemoryStream(cipherTextBytes)) { using (var cryptoStream = new CryptoStream(memoryStream, decryptor, CryptoStreamMode.Read)) { var plainTextBytes = new byte[cipherTextBytes.Length]; int totalDecryptedByteCount = 0; while (totalDecryptedByteCount < plainTextBytes.Length) { var decryptedByteCount = cryptoStream.Read( plainTextBytes, totalDecryptedByteCount, plainTextBytes.Length - totalDecryptedByteCount ); if (decryptedByteCount == 0) { break; } totalDecryptedByteCount += decryptedByteCount; } byte[] outputData = null; if (typeof(TModel) == typeof(string)) { outputData = Encoding.UTF8.GetBytes(plainTextBytes.ToString()); } else if (typeof(TModel) == typeof(byte[])) { outputData = plainTextBytes as byte[]; }; var rawString = Encoding.UTF8.GetString(outputData, 0, totalDecryptedByteCount); return (TModel)Convert.ChangeType(rawString, typeof(TModel)); } } } } } } catch (Exception ex) { // 记录异常 // LogHelper.LogException(ex); return (TModel)Convert.ChangeType(input, typeof(TModel)); } }}
在DbContext
中,重写OnModelCreating
方法,为User表的IdentificationNumber列,添加值转换器。
protected override void OnModelCreating(ModelBuilder modelBuilder){ base.OnModelCreating(modelBuilder); modelBuilder.Entity().Property(c => c.IdentificationNumber).HasConversion>();}
再次调用Add方法插入数据时,可以看到IdentificationNumber列已被加密了
Copyright © 2015-2022 世界频道网版权所有 备案号:琼ICP备2022009675号-1 联系邮箱:435 227 67@qq.com