欧美三区_成人在线免费观看视频_欧美极品少妇xxxxⅹ免费视频_a级毛片免费播放_鲁一鲁中文字幕久久_亚洲一级特黄

利用sqlclr實現數據庫服務器端數據加密解密

系統 2316 0

?

在公司中一同事用sqlclr寫數據遷移自動化執行腳本,發現他在執行腳本時對數據進行了加密。

?

個人覺得利用sqlclr對數據進行加密是一個解決數據網絡安全傳輸的不錯的方案。

?

以下是一個小的案例:

-------------------------執行:

declare @a nvarchar(100)

declare @b nvarchar(100)

set @a=dbo.fun('hi 你好')

set @b=dbo.fun1(@a)

print '加密后:'+@a

print '解密后:'+@b

--結果:

加密后:TIIRFZeZjZg=

解密后:hi 你好

-------------------------------------------加密標量函數:

public partial class UserDefinedFunctions

{

??? [Microsoft.SqlServer.Server.SqlFunction]

??? public static SqlString Fun(SqlString sql)

??? {

??????? // 在此處放置代碼

??????? return new SqlString(DesEncryptString(sql.Value, "12345678", "12345678"));

??? }

??? public static string DesEncryptString(string OriginalString, string EncryptKey, string EncryptOffset)

??? {

??????? byte[] btKey = Encoding.Default.GetBytes(EncryptKey);

??????? byte[] btIV = Encoding.Default.GetBytes(EncryptOffset);

??????? DESCryptoServiceProvider des = new DESCryptoServiceProvider();

??????? using (MemoryStream ms = new MemoryStream())

??????? {

??????????? byte[] inData = Encoding.Default.GetBytes(OriginalString);

??????????? try

??????????? {

??????????????? using (CryptoStream cs = new CryptoStream(ms, des.CreateEncryptor(btKey, btIV), CryptoStreamMode.Write))

??????????????? {

??????????????????? cs.Write(inData, 0, inData.Length);

????????????????? ??cs.FlushFinalBlock();

??????????????? }

?

??????????????? return Convert.ToBase64String(ms.ToArray());

??????????? }

??????????? catch

??????????? {

??????????????? return "";

??????????? }

??????? }

??? }

};

-------------------------------------------解密標量函數:

public partial class UserDefinedFunctions

{

??? [Microsoft.SqlServer.Server.SqlFunction]

??? public static SqlString Fun1(SqlString str)

??? {

??????? // 在此處放置代碼

?

??????? return new SqlString(DesDecryptString(str.Value, "12345678", "12345678"));

??? }

??? public static string DesDecryptString(string EncryptedString, string EncryptKey, string EncryptOffset)

??? {

??????? byte[] btKey = Encoding.Default.GetBytes(EncryptKey);

??????? byte[] btIV = Encoding.Default.GetBytes(EncryptOffset);

??????? DESCryptoServiceProvider des = new DESCryptoServiceProvider();

?

??????? using (MemoryStream ms = new MemoryStream())

??????? {

??????????? byte[] inData = Convert.FromBase64String(EncryptedString);

??????????? try

??????????? {

??????????????? using (CryptoStream cs = new CryptoStream(ms, des.CreateDecryptor(btKey, btIV), CryptoStreamMode.Write))

??????????????? {

??????????????????? cs.Write(inData, 0, inData.Length);

??????????????????? cs.FlushFinalBlock();

??????????????? }

?

??????????????? return Encoding.Default.GetString(ms.ToArray());

??????????? }

??????????? catch

??????????? {

??????????????? return "";

??????????? }

??????? }

??? }

};

?

?

?

利用sqlclr實現數據庫服務器端數據加密解密


更多文章、技術交流、商務合作、聯系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯系: 360901061

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對您有幫助就好】

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長會非常 感謝您的哦?。?!

發表我的評論
最新評論 總共0條評論
主站蜘蛛池模板: 久久久www视频 | 亚洲精品久久 | 亚洲激情一区 | 中文字幕在线观看视频一区 | 精品国产欧美一区二区 | 国产精品拍拍拍福利在线观看 | 色噜噜狠狠色综合欧洲selulu | 日韩在线免费 | 日韩高清一区二区 | 久草视频在线免费播放 | 免费观看av网站 | 亚洲国产欧美自拍 | 久久久99精品免费观看精品 | 国产福利在线观看永久免费 | 日本黄色大片免费 | 欧美videosex性极品hd | 99精品在线观看 | 天天操天天插天天干 | 欧美极品jizzhd欧美 | 高清国产一区二区三区四区五区 | 79thz.com| 日韩精选视频 | 国产亚洲综合在线 | 国产熟妇无码A片AAA毛片视频 | 奇米视频在线 | 国产精品亚洲第一区二区三区 | 久久精品国产免费看久久精品 | 国产成人91激情在线播放 | 亚洲一区二区三区四区在线观看 | 日本免费不卡在线一区二区三区 | 霍元甲之精武天下 | 欧美一级高潮片免费的 | 亚洲一区二区三 | 国产精品亚洲综合第一区 | 色色成人网| 国产福利99 | 精品一区二区三区水蜜桃 | 日日摸夜夜添欧美一区 | 国产伦精品一区二区 | 奇米777四色成人影视 | 成人综合网站 |