rc4解密就是加密的逆过程,因此可以用同一个函数解密。
void RC4_DeCRYPT_CRYPT(unsigned char * strData ,unsigned long nDatalen,unsigned char * strKey,unsigned long nKeylen )
{
unsigned char sBox[256] = { 0 };
int i =0, j = 0,ntemp = 0, key[256] = {0};
for(i=0;i<256;i++)
{
sBox[i]=i;
key[i]=strKey[i%nKeylen];
}
for (i=0; i<256; i++)
{
j=(j+sBox[i]+key[i])%256;
std::swap(sBox[i],sBox[j]);
}
i =0, j = 0;
for(int k=0;k<nDatalen;k++)
{
i=(i+1)%256;
j=(j+sBox[i])%256;
std::swap(sBox[i],sBox[j]);
ntemp=(sBox[i]+sBox[j])%256;
char ch = strData[k] ^ sBox[ntemp];
strData[k] = ch;
}
}
{
unsigned char sBox[256] = { 0 };
int i =0, j = 0,ntemp = 0, key[256] = {0};
for(i=0;i<256;i++)
{
sBox[i]=i;
key[i]=strKey[i%nKeylen];
}
for (i=0; i<256; i++)
{
j=(j+sBox[i]+key[i])%256;
std::swap(sBox[i],sBox[j]);
}
i =0, j = 0;
for(int k=0;k<nDatalen;k++)
{
i=(i+1)%256;
j=(j+sBox[i])%256;
std::swap(sBox[i],sBox[j]);
ntemp=(sBox[i]+sBox[j])%256;
char ch = strData[k] ^ sBox[ntemp];
strData[k] = ch;
}
}