下载 >  开发技术 >  C# > 对称分组加密算法RC2的C#实现

对称分组加密算法RC2的C#实现

2011-11-16 上传大小:249KB
RC2是由著名密码学家Ron Rivest设计的一种传统对称分组加密算法,它可作为DES算法的建议替代算法。它的输入和输出都是64比特。密钥的长度是从8字节到128字节可变,但目前的实现是8字节(1998年)。 此算法被设计为可容易地在16位的微处理器上实现。在一个IBM AT机上,RC2加密算法的执行可比DES算法快两倍(假设进行密钥扩展)。在C#中用RC2CryptoServiceProvider可以实现此算法。
算法原理:

1.根据计算机cpu序列号 ,硬盘ID,网卡硬件地址 号生成注册码:

//获取机器码

public static string getMachineCode()
{
string machineCode = "";
MD5CryptoServiceProvider provider1;
byte[] array1;
string text1;
string text2;
byte num1;
byte[] array2;
int num2;
provider1 = new MD5CryptoServiceProvider();
string cpuInfo = "";//cpu序列
                            号
ManagementClass cimobject = new ManagementClass("Win32_Processor");
ManagementObjectCollection moc = cimobject.GetInstances();
foreach (ManagementObject mo in moc)
{
cpuInfo += mo.Properties["ProcessorId"].Value.ToString();
}
//获取硬盘ID
string HDid = "";
ManagementClass cimobjectHDid = new ManagementClass("Win32_DiskDrive");
ManagementObjectCollection mocHDid = cimobjectHDid.GetInstances();
foreach (ManagementObject mo in mocHDid)
{
HDid += (string)mo.Properties["Model"].Value;
}
//获取网卡硬件地址
string strMac = "";
ManagementClass mc = new ManagementClass("Win32_NetworkAdapterConfiguration");
ManagementObjectCollection mocMac = mc.GetInstances();
foreach (ManagementObject mo in mocMac)
{
if ((bool)mo["IPEnabled"] == true)
strMac += mo["MacAddress"].ToString();
mo.Dispose();
}
array1 = provider1.ComputeHash(Encoding.Default.GetBytes(cpuInfo + strMac));
text1 = "ENTOPYMICROSYSTEMSDEVINIMMUHENDISLIK231456789ACD23456789AEFABGHJKLMNPRSTUVWYZXAHMETALIAKKASHAKANESKICI";
text2 = string.Empty;
array2 = array1;
for (num2 = 0; (num2 < array2.Length); num2 = (num2 + 1))
{
num1 = array2[num2];
text2 = string.Concat(text2, text1.Substring((num1 % text1.Length), 1));
}
machineCode = text2.Substring(0, 10);
return machineCode;
}

2.根据注册码按照RC2生成注册码:
//根据算法得到注册码
public static string getRegisterCode(string machineCode,string _configName)
{
string computeCode = "";
byte[] array1, array2, array3, array4;
MemoryStream stream1 = new MemoryStream();
BinaryFormatter formatter1 = new BinaryFormatter();
formatter1.Serialize(stream1, machineCode);
array1 = stream1.ToArray();

RC2CryptoServiceProvider provider11 = new RC2CryptoServiceProvider();

provider11.KeySize = 128;

#region
byte[] str1 = new byte[8] ;
byte[] str2 = new byte[16] ;
DataTable dt = Xml.GetAllDataFromXml("Config.xml");
if (dt != null && dt.Rows.Count > 0)
{
foreach(DataRow dr in dt.Rows)
{
if (dr[1].ToString() == _configName)
{
str1 = new byte[] { byte.Parse(dr[2].ToString()), byte.Parse(dr[3].ToString()), byte.Parse(dr[4].ToString()), byte.Parse(dr[5].ToString()), byte.Parse(dr[6].ToString()), byte.Parse(dr[7].ToString()), byte.Parse(dr[8].ToString()), byte.Parse(dr[9].ToString()) };
str2 = new byte[] { byte.Parse(dr[10].ToString()), byte.Parse(dr[11].ToString()), byte.Parse(dr[12].ToString()), byte.Parse(dr[13].ToString()), byte.Parse(dr[14].ToString()), byte.Parse(dr[15].ToString()), byte.Parse(dr[16].ToString()), byte.Parse(dr[17].ToString()),
byte.Parse(dr[18].ToString()), byte.Parse(dr[19].ToString()), byte.Parse(dr[20].ToString()), byte.Parse(dr[21].ToString()), byte.Parse(dr[22].ToString()), byte.Parse(dr[23].ToString()),byte.Parse(dr[24].ToString()),byte.Parse(dr[25].ToString())
};
break;
}
}
}
#endregion

array2 =str1 ;
array3 =  str2 ;
provider11.IV = array2;
provider11.Key = array2;
ICryptoTransform transform1 = provider11.CreateEncryptor();
stream1 = new MemoryStream();
CryptoStream stream2 = new CryptoStream(stream1, transform1, System.Security.Cryptography.CryptoStreamMode.Write);

try
{
stream2.Write(array1, 0, array1.Length);
stream2.FlushFinalBlock();
array4 = stream1.ToArray();
}

finally
{
stream1.Close();
stream2.Close();
}
stream1 = new MemoryStream();
formatter1.Serialize(stream1, array4);
computeCode = Convert.ToBase64String(stream1.ToArray()).Trim();
return computeCode;
}
3.check
public static bool checkRegisterCode(string machineCode, string registerCode,string configName)
{
string computeCode = getRegisterCode(machineCode, configName);
if (computeCode == registerCode)
{
return true;
}
else
return false;
}                        
...展开收缩
综合评分:4
开通VIP 立即下载

评论共有6条

流星_ 2014-05-07 15:18:44
比较不错,不够完善
hellogis0701 2014-01-08 09:37:04
不错,我的程序应用到了
smmtc3 2013-06-30 14:16:53
不错,不错,能够运行,谢谢分享
 
c# RC2加密和解密算法 立即下载
积分/C币:3
C# 对称法加密、解密dataset,算法使用了二进制流得方式进行加密、解密,提高效率 立即下载
积分/C币:3
加密解密算法 源代码 C 立即下载
积分/C币:3
RC2 立即下载
积分/C币:3
DES加密算法 C#.NET2008实现 立即下载
积分/C币:3
C++加解密算法源代码大全 立即下载
积分/C币:3
简单代码c#实现Rc4加密以及解密 立即下载
积分/C币:5
AES加密算法详解 AES加密算法详解大全 立即下载
积分/C币:3
DES加密算法C#实现 立即下载
积分/C币:3
DES加密算法.doc 立即下载
积分/C币:3

VIP会员动态

0 1 2
关闭
img

spring mvc+mybatis+mysql+maven+bootstrap 整合实现增删查改简单实例.zip

资源所需积分/C币 当前拥有积分 当前拥有C币
5 0 0
点击完成任务获取下载码
输入下载码
为了良好体验,不建议使用迅雷下载
img

对称分组加密算法RC2的C#实现

会员到期时间: 剩余下载个数: 剩余C币: 剩余积分:0
为了良好体验,不建议使用迅雷下载
VIP下载
您今日下载次数已达上限(为了良好下载体验及使用,每位用户24小时之内最多可下载20个资源)

积分不足!

资源所需积分/C币 当前拥有积分
您可以选择
开通VIP
4000万
程序员的必选
600万
绿色安全资源
现在开通
立省522元
或者
购买C币兑换积分 C币抽奖
img

资源所需积分/C币 当前拥有积分 当前拥有C币
5 4 45
为了良好体验,不建议使用迅雷下载
确认下载
img

资源所需积分/C币 当前拥有积分 当前拥有C币
5 0 0
为了良好体验,不建议使用迅雷下载
开通VIP
img

资源所需积分/C币 当前拥有积分 当前拥有C币
5 4 45
您的积分不足,将扣除 10 C币
为了良好体验,不建议使用迅雷下载
确认下载
下载
无法举报自己的资源

兑换成功

你当前的下载分为234开始下载资源
你还不是VIP会员
开通VIP会员权限,免积分下载
立即开通

你下载资源过于频繁,请输入验证码

您因违反CSDN下载频道规则而被锁定帐户,如有疑问,请联络:webmaster@csdn.net!

举报

若举报审核通过,可返还被扣除的积分

  • 举报人:
  • 被举报人:
  • 举报的资源分:
  • *类型:
  • *详细原因: