tcp/ip网络通讯安全是一个广受关注的话题,现在也有一些基于tcp/ip加密技术标准如SSL,TLS等。但很多时候编写一些简单的网络通讯把这标准加密应用添加进来乎一下子把程序变得复杂了,而实现自己的加密算法那就更加不可取;其实通过一些现有的加密的技术应用完全可以实现即简单又安全的网络通讯程序。首先保证网络通讯安全有两个方面,第一保证连接的有效性,其二就是保证内容即使被人拦截也难以从内容得到相关信息。
平常写网络程序在允许一个连接接入操作的时候,我们一般要对它进行一个有效性验证,如提供用户名密码或签名。
签名:
通过用户提供一分数据和数据相关签名信息,对方进行一个有效性验证。那这个数据和签名数据怎么做呢,其实现有加密技术中已经有一种描述提供了这种解决方案那就是RSA(非对称加密)。可以通过 RSA 的持有privatekey和publickey方进行一个数据签名,对方通过publickey进行一个验证.如果publickey和privatekey是配对的情况,那持有publickey就能验证成功,否则就会验证失败。在连接进行操作前可以通过这种方式进行处理,签名有效允许连接操作,无效的话可以直接把连接关闭。
下面介绍通过c#如何实现这种签名:
RasCrypto pri = new RasCrypto(); RasCrypto pub = new RasCrypto(); pub.PublicKey = pri.PublicKey; string name = "henry"; string singdata = pri.Sign(name); Console.WriteLine(pub.Verify(name, singdata));
RasCrypto是通过封装的类,源代码可以通过https://smarkdata.svn.codeplex.com/svn/Smark/Smark.Core/Smark.Core/RasCrypto.cs获取;在实际使用中最好是根据不同签名有不同的密对,这样即使某签名的密对被盗也不会影响其他用户的安全。
用户名密码:
基于用户名和密码验证是一种很常见的方式,但有个问题就是如何保证用户名和密码在通讯过程即使被截取了也难以得到用户名和密码呢?其实通过 RSA 也能够很好地解决这一问题。 RSA 提供public key加密而private key解密的方式,可以把public key提供给请求方就行了,private key保存在服务端;这样就可以保证加密的东西只有服务端才有解密,即使加密信息被其他人拦截也难以获取原有信息。
下面介绍通过c#使用ras进行加解密
RasCrypto server = new RasCrypto(); RasCrypto client = new RasCrypto(); client.PublicKey = server.PublicKey; string name = "henry"; string pwd = "123456"; string ename = client.Encrypt(name); string epwd = client.Encrypt(pwd); string dname = server.Decrypt(ename); string dpwd = server.Decrypt(epwd); Console.WriteLine("name:{0}", name); Console.WriteLine("pwd:{0}", pwd); Console.WriteLine("-----------------------------------------------------------"); Console.WriteLine("ename:{0}", ename); Console.WriteLine("epwd:{0}", epwd); Console.WriteLine("-----------------------------------------------------------"); Console.WriteLine("dname:{0}", dname); Console.WriteLine("dpwd:{0}", dpwd); Console.WriteLine("-----------------------------------------------------------");
为了应用更安全,针对不同的连接生成不同的RSA密对,这样就能保证每个连接的各自安全性.
前面提到的 RSA 可以进行数据加解密,其安全性也非常可靠;但有个缺点就是RSA对数据比多的时候加密比较慢,有些 RSA 加密的实现还有数据长度的限制。所以在很多情况下就要选择别的加密方式,这里介绍DES(对称加密)。不过对称加密有个缺点就是密对双方都必须一样,这样就会导致一个问题就从某一方获取密对就能对数据加密和解密工作。所以对称加的密对保护就显示非常重要的,这个工作可以交给 RSA 来做。
以下是c#运用 RSA +DES的加解密方法
RasCrypto server = new RasCrypto(); RasCrypto client = new RasCrypto(); client.PublicKey = server.PublicKey; DESCrypto serverdes = new DESCrypto(); DESCrypto clientdes = new DESCrypto(); //获取没加密的key,iv DESCrypto.DESInfo info = clientdes.KeyInfo; Console.WriteLine("KEY: "+Smark.Core.Functions.ToString(info.Key)); Console.WriteLine("IV: "+Smark.Core.Functions.ToString(info.IV)); Console.WriteLine(""); //设置相应的RSA信息 serverdes.PrivateRas = server; clientdes.PublicRas = client; //获取了设置RSA信息的key,iv info = clientdes.KeyInfo; Console.WriteLine("KEY: " + Smark.Core.Functions.ToString(info.Key)); Console.WriteLine("IV: " + Smark.Core.Functions.ToString(info.IV)); //数据加密 serverdes.KeyInfo = info; string value = "[email protected]", evalue = null, dvalue = null; evalue = serverdes.Encrypt(value); dvalue = clientdes.Decrypt(evalue); Console.WriteLine("VALUE: " + value); Console.WriteLine("EVALUE: " + evalue); Console.WriteLine("DVALUE: " + dvalue); Console.WriteLine(""); evalue = clientdes.Encrypt(value); dvalue = serverdes.Decrypt(evalue); Console.WriteLine("VALUE: " + value); Console.WriteLine("EVALUE: " + evalue); Console.WriteLine("DVALUE: " + dvalue); Console.WriteLine(""); Console.Read();
通过RSA和DES就能够简单地实现可靠的网络通讯安全,不过有些朋友喜欢构建自己的加密方法,在这里并不见意这样做;因为自己构建的加密方法的可靠性并没有得到验证,并不像现有的加密方法经过长时候实践和大量的应用总结出来。
相关资料:
DES http://zh.wikipedia.org/wiki/%E8%B3%87%E6%96%99%E5%8A%A0%E5%AF%86%E6%A8%99%E6%BA%96
RSA http://zh.wikipedia.org/wiki/RSA%E5%8A%A0%E5%AF%86%E6%BC%94%E7%AE%97%E6%B3%95