strLast = txtrandom.Text + "00000000";
initdata = txtSendata.Text;
//initdata = "04E000381E3F00381CD05E00000000910E315041592E5359532E4444453031";
if (initdata.Length / 8 == 0)
{
initdata = initdata + "8000000000000000";
}
else
{
//这段话的意思:m表示还缺的个数,如果只差2,那么直接加80构成16个数,若不等于2,则先加80,再添加0
int m = 0;
int n = 0;
m = 16 - initdata.Length % 16;
if (m == 2)
{
initdata = initdata + "80";
}
else
{
n = 16 * (initdata.Length / 16 + 1);
initdata = initdata + "80";
initdata = initdata.PadRight(n, '0');
}
}
slen = Convert.ToByte(initdata.Length / 2);
skeylen = Convert.ToByte(s_TK_MF.Length / 2);
macdata = MyMAC(strLast, s_TK_MF, skeylen, initdata, slen);
int mt = 0;
string myXor = "";
string MACData = "";
StringBuilder desdata1 = new StringBuilder(100);
if (skeylen!=8&&skeylen!=16)
{
MessageBox.Show("密码长度有误,请重新输入密码") ;
txtDES.Text = string.Empty;
txt3DES.Text = string.Empty;
}
for (int i = 0; i < slen/8; i++)
{
myXor = strXorstr(strLast, initdata.Substring(i * 16, 16));
if (slen/8-i>1)
{
mt = dc_des_hex(txtDES.Text, myXor, desdata1, 1);
if (mt==0)
{
strLast = "";
strLast = Convert.ToString(desdata1);
}
}
else
{
mt = dc_tripledes_hex(txt3DES.Text, myXor, desdata1, 1);
if (mt==0)
{
strLast = "";
strLast = Convert.ToString(desdata1);
}
}
}
MACData = Convert.ToString(desdata1).Substring(0, 8);
initdata = txtSendata.Text;
//initdata = "04E000381E3F00381CD05E00000000910E315041592E5359532E4444453031";
if (initdata.Length / 8 == 0)
{
initdata = initdata + "8000000000000000";
}
else
{
//这段话的意思:m表示还缺的个数,如果只差2,那么直接加80构成16个数,若不等于2,则先加80,再添加0
int m = 0;
int n = 0;
m = 16 - initdata.Length % 16;
if (m == 2)
{
initdata = initdata + "80";
}
else
{
n = 16 * (initdata.Length / 16 + 1);
initdata = initdata + "80";
initdata = initdata.PadRight(n, '0');
}
}
slen = Convert.ToByte(initdata.Length / 2);
skeylen = Convert.ToByte(s_TK_MF.Length / 2);
macdata = MyMAC(strLast, s_TK_MF, skeylen, initdata, slen);
int mt = 0;
string myXor = "";
string MACData = "";
StringBuilder desdata1 = new StringBuilder(100);
if (skeylen!=8&&skeylen!=16)
{
MessageBox.Show("密码长度有误,请重新输入密码") ;
txtDES.Text = string.Empty;
txt3DES.Text = string.Empty;
}
for (int i = 0; i < slen/8; i++)
{
myXor = strXorstr(strLast, initdata.Substring(i * 16, 16));
if (slen/8-i>1)
{
mt = dc_des_hex(txtDES.Text, myXor, desdata1, 1);
if (mt==0)
{
strLast = "";
strLast = Convert.ToString(desdata1);
}
}
else
{
mt = dc_tripledes_hex(txt3DES.Text, myXor, desdata1, 1);
if (mt==0)
{
strLast = "";
strLast = Convert.ToString(desdata1);
}
}
}
MACData = Convert.ToString(desdata1).Substring(0, 8);
txtMAC.Text = MACData.Substring(0, 8);
软件界面如图所示: