服务器之家:专注于服务器技术及软件下载分享
分类导航

PHP教程|ASP.NET教程|Java教程|ASP教程|编程技术|正则表达式|C/C++|IOS|C#|Swift|Android|VB|R语言|JavaScript|易语言|vb.net|

服务器之家 - 编程语言 - C# - C# 数据库链接字符串加密解密工具代码详解

C# 数据库链接字符串加密解密工具代码详解

2022-02-23 13:47begrateful C#

本文通过代码给大家介绍C# 数据库链接字符串加密解密工具的相关知识,实现思路大概是使用两个数对连接字符串进行加密,再用这两个数进行解密,具体详细代码,大家参考下本文

有些项目尤其是winform或者是wpf项目,针对一些工具形式的小项目,不想软件流出去之后,懂程序的的拿到手之后一看配置文件就知道了我们数据库的用户名和密码,如果外网能访问的话,那就麻烦大了。所以这里为了防止项目外泄之后这些信息不被别人看到,我们就需要对链接字符串或者其他重要信息进行加密,用的时候在解密。

思路:使用两个数对连接字符串进行加密,再用这两个数进行解密。

?
1
<add key="configstring" value="4hsxbrnxtken0zokdewfe501tksqlzuyj0zf+c7s5+gpd1sbwbiuh4pg6jefgcnctfr0qfw8fn40m/s8xmqq+8srl8tamlo23z6gsmaqjom="/>

C# 数据库链接字符串加密解密工具代码详解

直接上代码:

1:定义一个初始化源数据的类。

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
public class configinformation
 {
  private static configinformation _configinformation;
  public configinformation instance
  {
   get
   {
    if (_configinformation == null)
    {
     _configinformation = new configinformation();
    }
    return _configinformation;
   }
  }
  // 数据库链接字符串加解密 key value
  public static string key = "27e167e9-2660-4bc1-bea0-c8781a9f01cb";
  public static string vector = "8280d587-f9bf-4127-bbfa-5e0b4b672958";
 }

2:加解密方法:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
/// <summary>
 /// 加密 解密
 /// </summary>
 public class decryptandencryptionhelper
 {
  private readonly symmetricalgorithm _symmetricalgorithm;
  private const string defkey = "qazwsxedcrfvtgb!@#$%^&*(tgbrfvedcwsxqaz)(*&^%$#@!";
  private string _key = "";
  public string key
  {
   get { return _key; }
   set
   {
    if (!string.isnullorempty(value))
    {
     _key = value;
    }
    else
    {
     _key = defkey;
    }
   }
  }
  private const string defiv = "tgbrfvedcwsxqaz)(*&^%$#@!qazwsxedcrfvtgb!@#$%^&*(";
  private string _iv = "";
  public string iv
  {
   get { return _iv; }
   set
   {
    if (!string.isnullorempty(value))
    {
     _iv = value;
    }
    else
    {
     _iv = defiv;
    }
   }
  }
  public decryptandencryptionhelper()
  {
   _symmetricalgorithm = new rijndaelmanaged();
  }
  public decryptandencryptionhelper(string key, string iv)
  {
   _symmetricalgorithm = new rijndaelmanaged();
   _key = string.isnullorempty(key) ? defkey : key;
   _iv = string.isnullorempty(iv) ? defiv : iv;
  }
  /// <summary>
  /// get key
  /// </summary>
  /// <returns>密钥</returns>
  private byte[] getlegalkey()
  {
   _symmetricalgorithm.generatekey();
   byte[] byttemp = _symmetricalgorithm.key;
   int keylength = byttemp.length;
   if (_key.length > keylength)
    _key = _key.substring(0, keylength);
   else if (_key.length < keylength)
    _key = _key.padright(keylength, '#');
   return asciiencoding.ascii.getbytes(_key);
  }
  /// <summary>
  /// get iv
  /// </summary>
  private byte[] getlegaliv()
  {
   _symmetricalgorithm.generateiv();
   byte[] byttemp = _symmetricalgorithm.iv;
   int ivlength = byttemp.length;
   if (_iv.length > ivlength)
    _iv = _iv.substring(0, ivlength);
   else if (_iv.length < ivlength)
    _iv = _iv.padright(ivlength, '#');
   return asciiencoding.ascii.getbytes(_iv);
  }
  /// <summary>
  /// encrypto 加密
  /// </summary>
  public string encrypto(string source)
  {
   byte[] bytin = utf8encoding.utf8.getbytes(source);
   memorystream ms = new memorystream();
   _symmetricalgorithm.key = getlegalkey();
   _symmetricalgorithm.iv = getlegaliv();
   icryptotransform encrypto = _symmetricalgorithm.createencryptor();
   cryptostream cs = new cryptostream(ms, encrypto, cryptostreammode.write);
   cs.write(bytin, 0, bytin.length);
   cs.flushfinalblock();
   ms.close();
   byte[] bytout = ms.toarray();
   return convert.tobase64string(bytout);
  }
  /// <summary>
  /// decrypto 解密
  /// </summary>
  public string decrypto(string source)
  {
   byte[] bytin = convert.frombase64string(source);
   memorystream ms = new memorystream(bytin, 0, bytin.length);
   _symmetricalgorithm.key = getlegalkey();
   _symmetricalgorithm.iv = getlegaliv();
   icryptotransform encrypto = _symmetricalgorithm.createdecryptor();
   cryptostream cs = new cryptostream(ms, encrypto, cryptostreammode.read);
   streamreader sr = new streamreader(cs);
   return sr.readtoend();
  }
 }

3:使用

?
1
2
3
4
5
6
// 获取加密的链接字符串,然后解密
string enstring = configurationmanager.appsettings["configstring"];
decryptandencryptionhelper helper = new decryptandencryptionhelper(configinformation.key, configinformation.vector);
// 明文
var configstr = helper.decrypto(enstring);
return configstr;

这样至少保证了数据的不外泄。

注意:这个加密和解密的算法方法,应该放在服务器。通过请求加解密方法。不应该放在本地代码里,技术牛的的人,把你的项目反编译一样可以看到源代码。

C# 数据库链接字符串加密解密工具代码详解

C# 数据库链接字符串加密解密工具代码详解

 我们在把加密源数据找出来。

C# 数据库链接字符串加密解密工具代码详解

所以这个加解密代码不能写在本地,必须部署到安全的服务器上。

总结

以上所述是小编给大家介绍的c# 数据库链接字符串加密解密工具代码详解,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对服务器之家网站的支持!

原文链接:http://www.cnblogs.com/wendj/p/9019160.html

延伸 · 阅读

精彩推荐
  • C#利用C#实现网络爬虫

    利用C#实现网络爬虫

    这篇文章主要介绍了利用C#实现网络爬虫,完整的介绍了C#实现网络爬虫详细过程,感兴趣的小伙伴们可以参考一下...

    C#教程网11852021-11-16
  • C#三十分钟快速掌握C# 6.0知识点

    三十分钟快速掌握C# 6.0知识点

    这篇文章主要介绍了C# 6.0的相关知识点,文中介绍的非常详细,通过这篇文字可以让大家在三十分钟内快速的掌握C# 6.0,需要的朋友可以参考借鉴,下面来...

    雨夜潇湘8272021-12-28
  • C#如何使用C#将Tensorflow训练的.pb文件用在生产环境详解

    如何使用C#将Tensorflow训练的.pb文件用在生产环境详解

    这篇文章主要给大家介绍了关于如何使用C#将Tensorflow训练的.pb文件用在生产环境的相关资料,文中通过示例代码介绍的非常详细,需要的朋友可以参考借鉴...

    bbird201811792022-03-05
  • C#C#设计模式之Strategy策略模式解决007大破密码危机问题示例

    C#设计模式之Strategy策略模式解决007大破密码危机问题示例

    这篇文章主要介绍了C#设计模式之Strategy策略模式解决007大破密码危机问题,简单描述了策略模式的定义并结合加密解密算法实例分析了C#策略模式的具体使用...

    GhostRider10972022-01-21
  • C#深入理解C#的数组

    深入理解C#的数组

    本篇文章主要介绍了C#的数组,数组是一种数据结构,详细的介绍了数组的声明和访问等,有兴趣的可以了解一下。...

    佳园9492021-12-10
  • C#C#微信公众号与订阅号接口开发示例代码

    C#微信公众号与订阅号接口开发示例代码

    这篇文章主要介绍了C#微信公众号与订阅号接口开发示例代码,结合实例形式简单分析了C#针对微信接口的调用与处理技巧,需要的朋友可以参考下...

    smartsmile20127762021-11-25
  • C#SQLite在C#中的安装与操作技巧

    SQLite在C#中的安装与操作技巧

    SQLite,是一款轻型的数据库,用于本地的数据储存。其优点有很多,下面通过本文给大家介绍SQLite在C#中的安装与操作技巧,感兴趣的的朋友参考下吧...

    蓝曈魅11162022-01-20
  • C#VS2012 程序打包部署图文详解

    VS2012 程序打包部署图文详解

    VS2012虽然没有集成打包工具,但它为我们提供了下载的端口,需要我们手动安装一个插件InstallShield。网上有很多第三方的打包工具,但为什么偏要使用微软...

    张信秀7712021-12-15