分享
 
 
 

C#几种加密算法,包括MD5

王朝c#·作者佚名  2006-11-24
窄屏简体版  字體: |||超大  

MD5算法:

using System;

using System.Text;

namespace BaseStationPDA

{

/**//// <summary>

/// Summary description for MD5.

/// </summary>

public class MD5

{

const int BITS_TO_A_BYTE = 8;

const int BYTES_TO_A_WORD = 4;

const int BITS_TO_A_WORD = 32;

private static long[] m_lOnBits = new long[30 + 1];

private static long[] m_l2Power = new long[30 + 1];

private static long LShift(long lValue, long iShiftBits)

{

long LShift = 0;

if (iShiftBits == 0)

{

LShift = lValue;

return LShift;

}

else

{

if( iShiftBits == 31)

{

if (Convert.ToBoolean(lValue & 1))

{

LShift = 0x80000000;

}

else

{

LShift = 0;

}

return LShift;

}

else

{

if( iShiftBits < 0 || iShiftBits > 31)

{

// Err.Raise 6;

}

}

}

if (Convert.ToBoolean((lValue & m_l2Power[31 - iShiftBits])))

{

LShift = ((lValue & m_lOnBits[31 - (iShiftBits + 1)]) * m_l2Power[iShiftBits]) | 0x80000000;

}

else

{

LShift = ((lValue & m_lOnBits[31 - iShiftBits]) * m_l2Power[iShiftBits]);

}

return LShift;

}

private static long RShift(long lValue, long iShiftBits)

{

long RShift = 0;

if (iShiftBits == 0)

{

RShift = lValue;

return RShift;

}

else

{

if( iShiftBits == 31)

{

if (Convert.ToBoolean(lValue & 0x80000000))

{

RShift = 1;

}

else

{

RShift = 0;

}

return RShift;

}

else

{

if( iShiftBits < 0 || iShiftBits > 31)

{

// Err.Raise 6;

}

}

}

RShift = (lValue & 0x7FFFFFFE) / m_l2Power[iShiftBits];

if (Convert.ToBoolean((lValue & 0x80000000)))

{

RShift = (RShift | (0x40000000 / m_l2Power[iShiftBits - 1]));

}

return RShift;

}

private static long RotateLeft(long lValue, long iShiftBits)

{

long RotateLeft = 0;

RotateLeft = LShift(lValue, iShiftBits) | RShift(lValue, (32 - iShiftBits));

return RotateLeft;

}

private static long AddUnsigned(long lX, long lY)

{

long AddUnsigned = 0;

long lX4 = 0;

long lY4 = 0;

long lX8 = 0;

long lY8 = 0;

long lResult = 0;

lX8 = lX & 0x80000000;

lY8 = lY & 0x80000000;

lX4 = lX & 0x40000000;

lY4 = lY & 0x40000000;

lResult = (lX & 0x3FFFFFFF) + (lY & 0x3FFFFFFF);

if (Convert.ToBoolean(lX4 & lY4))

{

lResult = lResult ^ 0x80000000 ^ lX8 ^ lY8;

}

else if( Convert.ToBoolean(lX4 | lY4))

{

if (Convert.ToBoolean(lResult & 0x40000000))

{

lResult = lResult ^ 0xC0000000 ^ lX8 ^ lY8;

}

else

{

lResult = lResult ^ 0x40000000 ^ lX8 ^ lY8;

}

}

else

{

lResult = lResult ^ lX8 ^ lY8;

}

AddUnsigned = lResult;

return AddUnsigned;

}

private static long md5_F(long x, long y, long z)

{

long md5_F = 0;

md5_F = (x & y) | (( ~x) & z);

return md5_F;

}

private static long md5_G(long x, long y, long z)

{

long md5_G = 0;

md5_G = (x & z) | (y & ( ~z));

return md5_G;

}

private static long md5_H(long x, long y, long z)

{

long md5_H = 0;

md5_H = (x ^ y ^ z);

return md5_H;

}

private static long md5_I(long x, long y, long z)

{

long md5_I = 0;

md5_I = (y ^ (x | (~z)));

return md5_I;

}

private static void md5_FF(ref long a, long b, long c, long d, long x, long s, long ac)

{

a = AddUnsigned(a, AddUnsigned(AddUnsigned(md5_F(b, c, d), x), ac));

a = RotateLeft(a, s);

a = AddUnsigned(a, b);

}

private static void md5_GG(ref long a, long b, long c, long d, long x, long s, long ac)

{

a = AddUnsigned(a, AddUnsigned(AddUnsigned(md5_G(b, c, d), x), ac));

a = RotateLeft(a, s);

a = AddUnsigned(a, b);

}

private static void md5_HH(ref long a, long b, long c, long d, long x, long s, long ac)

{

a = AddUnsigned(a, AddUnsigned(AddUnsigned(md5_H(b, c, d), x), ac));

a = RotateLeft(a, s);

a = AddUnsigned(a, b);

}

private static void md5_II(ref long a, long b, long c, long d, long x, long s, long ac)

{

a = AddUnsigned(a, AddUnsigned(AddUnsigned(md5_I(b, c, d), x), ac));

a = RotateLeft(a, s);

a = AddUnsigned(a, b);

}

private static long[] ConvertToWordArray(string sMessage)

{

long[] ConvertToWordArray = null;

int lMessageLength = 0;

int lNumberOfWords = 0;

long[] lWordArray = null;

int lBytePosition = 0;

int lByteCount = 0;

int lWordCount = 0;

const int MODULUS_BITS = 512;

const int CONGRUENT_BITS = 448;

lMessageLength = sMessage.Length;

lNumberOfWords = (((lMessageLength + ((MODULUS_BITS - CONGRUENT_BITS) / BITS_TO_A_BYTE)) / (MODULUS_BITS / BITS_TO_A_BYTE)) + 1) * (MODULUS_BITS / BITS_TO_A_WORD);

lWordArray = new long[lNumberOfWords];

lBytePosition = 0;

lByteCount = 0;

while(lByteCount < lMessageLength)

{

lWordCount = lByteCount / BYTES_TO_A_WORD;

lBytePosition = (lByteCount % BYTES_TO_A_WORD) * BITS_TO_A_BYTE;

lWordArray[lWordCount]

[1] [2] [3] 下一页

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
2023年上半年GDP全球前十五强
 百态   2023-10-24
美众议院议长启动对拜登的弹劾调查
 百态   2023-09-13
上海、济南、武汉等多地出现不明坠落物
 探索   2023-09-06
印度或要将国名改为“巴拉特”
 百态   2023-09-06
男子为女友送行,买票不登机被捕
 百态   2023-08-20
手机地震预警功能怎么开?
 干货   2023-08-06
女子4年卖2套房花700多万做美容:不但没变美脸,面部还出现变形
 百态   2023-08-04
住户一楼被水淹 还冲来8头猪
 百态   2023-07-31
女子体内爬出大量瓜子状活虫
 百态   2023-07-25
地球连续35年收到神秘规律性信号,网友:不要回答!
 探索   2023-07-21
全球镓价格本周大涨27%
 探索   2023-07-09
钱都流向了那些不缺钱的人,苦都留给了能吃苦的人
 探索   2023-07-02
倩女手游刀客魅者强控制(强混乱强眩晕强睡眠)和对应控制抗性的关系
 百态   2020-08-20
美国5月9日最新疫情:美国确诊人数突破131万
 百态   2020-05-09
荷兰政府宣布将集体辞职
 干货   2020-04-30
倩女幽魂手游师徒任务情义春秋猜成语答案逍遥观:鹏程万里
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案神机营:射石饮羽
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案昆仑山:拔刀相助
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案天工阁:鬼斧神工
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案丝路古道:单枪匹马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:与虎谋皮
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:李代桃僵
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:指鹿为马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:小鸟依人
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:千金买邻
 干货   2019-11-12
 
推荐阅读
 
 
 
>>返回首頁<<
 
靜靜地坐在廢墟上,四周的荒凉一望無際,忽然覺得,淒涼也很美
© 2005- 王朝網路 版權所有