RC4加密算法详解

RC4序列密码

RC4序列密码是大名鼎鼎的RSA三人组中的头号人物Ron Rivest在1987年设计的密钥长度可变的流加密算法簇。RC4算法是一种在电子信息领域加密的技术手段,用于无线通信网络,是一种电子密码,只有经过授权(缴纳相应费用)的用户才能享受该服务。

原理

💻 RC4算法的原理很简单,包括初始化算法(KSA)和伪随机子密码生成算法(PRGA)两大部分。假设S-box的长度为256,密钥长度为Len。先来看看算法的初始化部分(用C代码表示):

    参数1是一个256长度的char型数组,定义为: unsigned char sBox[256];
    参数2是密钥,其内容可以随便定义:char key[256];
    参数3是密钥的长度,Len = strlen(key);

在初始化的过程中,密钥的主要功能是将S-box搅乱,i确保S-box的每个元素都得到处理,j保证S-box的搅乱是随机的。而不同的S-box在经过伪随机子密码生成算法的处理后可以得到不同的子密钥序列,将S-box和明文进行xor运算,得到密文,解密过程也完全相同。 再来看看算法的加密部分(用C代码表示):

    参数1是上边rc4_init函数中,被搅乱的S-box;
    参数2是需要加密的数据data;
    参数3是data的长度.

💌看了上面的文字,你是不是也会有一定的疑惑,请接着看下面的图片,这将会使你恍然大悟!!!当然,如果你去看代码,你会发现 代码是根据你自己输入你想加密的内容,若有不懂,可以再下方留言哦!

在这里插入图片描述

🌤️下面直接上代码!

代码

#include <stdio.h>
#include <string.h>
typedef unsigned long ULONG;

/*初始化函数*/
void rc4_init(unsigned char*s, unsigned char*key, unsigned long Len)
{
    int i = 0, j = 0;
    char k[256] = { 0 };
    unsigned char tmp = 0;
    for (i = 0; i<256; i++)
    {
        s[i] = i;
        k[i] = key[i%Len];
    }
    for (i = 0; i<256; i++)
    {
        j = (j + s[i] + k[i]) % 256;
        tmp = s[i];
        s[i] = s[j];//交换s[i]和s[j]
        s[j] = tmp;
    }
}

/*加解密*/
void rc4_crypt(unsigned char*s, unsigned char*Data, unsigned long Len)
{
    int i = 0, j = 0, t = 0;
    unsigned long k = 0;
    unsigned char tmp;
    for (k = 0; k<Len; k++)
    {
        i = (i + 1) % 256;
        j = (j + s[i]) % 256;
        tmp = s[i];
        s[i] = s[j];//交换s[x]和s[y]
        s[j] = tmp;
        t = (s[i] + s[j]) % 256;
        Data[k] ^= s[t];
    }
}

int main()
{
    unsigned char s[256] = { 0 }, s2[256] = { 0 };//S-box
    char key[256];
    puts("请输入需要加密的明文:");
    gets(key);
    char pData[512];
    puts("请输入一个用来加密的数据Data:");
    gets(pData);
    unsigned long len = strlen(pData);
    printf("这是Pdata的长度:%d\n\n",len);
    int i;
    printf("pData=%s\n", pData); 
    printf("key=%s,length=%d\n\n", key, strlen(key)); 
    rc4_init(s, (unsigned char*)key, strlen(key));//已经完成了初始化 
    printf("完成对S[i]的初始化,如下:\n\n"); 
    for (i = 0; i<256; i++) 
    { 
        printf("%02X", s[i]); 
        if (i && (i + 1) % 16 == 0)putchar('\n'); 
    } 
    printf("\n\n"); 
    for (i = 0; i<256; i++)//用s2[i]暂时保留经过初始化的s[i],很重要的!!! 
    { 
        s2[i] = s[i]; 
    } 
    printf("已经初始化,现在加密:\n\n"); 
    rc4_crypt(s, (unsigned char*)pData, len);//加密 
    printf("pData=%s\n\n", pData); 
    printf("已经加密,现在解密:\n\n"); 
    //rc4_init(s,(unsignedchar*)key,strlen(key));//初始化密钥 
    rc4_crypt(s2, (unsigned char*)pData, len);//解密 
    printf("pData=%s\n\n", pData); 
    return 0; 
}

结果

在这里插入图片描述
如果对你有帮助,请多多支持小编哦!

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值