当前位置:  编程技术>.net/c#/asp.net

des加密解密源码 C# key值问题分析

    来源: 互联网  发布时间:2014-10-26

    本文导语:  公司协议安全需求、需要对传输内容做des、md5加密。 因为是新人、刚交给我这个任务的时候有点眩晕。就开始在网上找各种des加密的内容。因为不懂以为需要把原理也搞明白,最后误了时间、把自己也搞糊涂了。当然,逻辑能...

公司协议安全需求、需要对传输内容做des、md5加密。

因为是新人、刚交给我这个任务的时候有点眩晕。就开始在网上找各种des加密的内容。因为不懂以为需要把原理也搞明白,最后误了时间、把自己也搞糊涂了。当然,逻辑能力强、有兴趣的朋友可以试着去搞搞。

先贴加密、解密的源码:

代码如下:

///       

/// 加密数据      

///       

///       

///       

///       

public static string Encrypt(string Text, string sKey)         {          

DESCryptoServiceProvider des = new DESCryptoServiceProvider();          

byte[] inputByteArray;          

inputByteArray = Encoding.Default.GetBytes(Text);          

des.Key = ASCIIEncoding.ASCII.GetBytes(System.Web.Security.FormsAuthentication.HashPasswordForStoringInConfigFile(sKey, "md5").Substring(0, 8));          

des.IV = ASCIIEncoding.ASCII.GetBytes(System.Web.Security.FormsAuthentication.HashPasswordForStoringInConfigFile(sKey, "md5").Substring(0, 8));          

System.IO.MemoryStream ms = new System.IO.MemoryStream();          

CryptoStream cs = new CryptoStream(ms, des.CreateEncryptor(), CryptoStreamMode.Write);          

cs.Write(inputByteArray, 0, inputByteArray.Length);          

cs.FlushFinalBlock();          

StringBuilder ret = new StringBuilder();          

foreach (byte b in ms.ToArray())             {              

ret.AppendFormat("{0:X2}", b);          

}          

return ret.ToString();      

}

        #endregion

///       

/// 解密数据      

///       

///       

///       

///       

public static string Decrypt(string Text, string sKey)         {          

DESCryptoServiceProvider des = new DESCryptoServiceProvider();          

int len;          

len = Text.Length / 2;          

byte[] inputByteArray = new byte[len];          

int x, i;          

for (x = 0; x < len; x++)             {              

i = Convert.ToInt32(Text.Substring(x * 2, 2), 16);              

inputByteArray[x] = (byte)i;             }          

des.Key = ASCIIEncoding.ASCII.GetBytes(System.Web.Security.FormsAuthentication.HashPasswordForStoringInConfigFile(sKey, "md5").Substring(0, 8));          

des.IV = ASCIIEncoding.ASCII.GetBytes(System.Web.Security.FormsAuthentication.HashPasswordForStoringInConfigFile(sKey, "md5").Substring(0, 8));          

System.IO.MemoryStream ms = new System.IO.MemoryStream();          

CryptoStream cs = new CryptoStream(ms, des.CreateDecryptor(), CryptoStreamMode.Write);          

cs.Write(inputByteArray, 0, inputByteArray.Length);          

cs.FlushFinalBlock();          

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

#endregion

因为是第一次接触des并且公司协议文档的需求、让我对这段代码里面迷糊的有:

1:俩个参数

Text 是要加密的内容

sKey是作为加密内容的密钥。当然加密、解密时候的sKey值,是要保持一致的。

2:des对象的key值

这个key值和IV值是固定的8位长度,一定要牢记。因为咱们的参数sKey是不定长度的、所以采取了一个方式就是对其进行MD5加密、然后再截取他的前8位。这是为了在解密的时候保证key一致。不然会解密出错。

最后,我说一下做为新人,我感觉牢记的几个地方,或许是大大们眼中写des必需的几点~~别喷我啊、

几个必要的对象:

DESCryptoServiceProvider 没有它你想怎么des呢、嘿嘿

MemoryStream    存储在内存的流对象

CryptoStream    定义将数据流链接到加密转换流。通过它写入MemoryStream对象当中

最后转换成String。


    
 
 
 
本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。












  • 相关文章推荐
  • 紧急求助:如何在Linux下用C语言实现MD5/DES解密
  • java命名空间javax.crypto.spec类deskeyspec的类成员方法: des_key_len定义及介绍
  • DES加密的问题!!
  • java命名空间javax.crypto.spec类desedekeyspec的类成员方法: des_ede_key_len定义及介绍
  • 有熟悉3Des算法的人吗?
  • des加密问题求助
  • 哪里有 DES 算法的Java原码?
  • 求DES的JAVA源码
  • 怎么样比较已经被DES的加密后的密码?
  • .net/c#/asp.net iis7站长之家
  • 和DES有关的java问题,高手请进,急啊~~~~~~
  • 和DES有关的JAVA问题,有兴趣的请进
  • linux下,使用openssl的des加密,密钥如何导出?
  • rc4,idea,rsa,des 等算法的英文全称是什么?
  • 求对称加密DES算法与非对称加密RSA算法!(可用)
  • 跪求3DES ECB 模式的加密C源码
  • 字符串desede 3des加密示例分享
  • 一个可逆加密的类(使用3DES加密)
  • 6个0和6个1作为密钥用3des加密结果一样,请帮我看下这个程序的问题
  • 求助DES加密问题
  • 每日Oracle:配置日志模式的相关参数log_archive_des
  • 使用java自带des加密算法实现文件加密和字符串加密


  • 站内导航:


    特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

    ©2012-2021,,E-mail:www_#163.com(请将#改为@)

    浙ICP备11055608号-3