RC4
来源:互联网 发布:淘宝球鞋店 编辑:程序博客网 时间:2024/05/18 02:21
RC4加密算法是大名鼎鼎的RSA三人组中的头号人物Ronald Rivest在1987年设计的密钥长度可变的流加密算法簇。之所以称其为簇,是由于其核心部分的S-box长度可为任意,但一般为256字节。该算法的速度可以达到DES加密的10倍左右,且具有很高级别的非线性。RC4起初是用于保护商业机密的。但是在1994年9月,它的算法被发布在互联网上,也就不再有什么商业机密了。RC4也被叫做ARC4(Alleged RC4——所谓的RC4),因为RSA从来就没有正式发布过这个算法。
PS:
改动前:printf("加密后的内容为%0x\n\n",ch);
改动后:printf("加密后的内容为%s\n\n",ch);
#include#include #include #define MAX 1024FILE *fp;char ch[1024],ch1,ch2;char filename1[20],filename2[20];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])%6;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<=MAX;k++){i=(i+1)%6;j=(j+s[i])%6;tmp = s[i];s[i] = s[j]; //交换s[x]和s[y]s[j] = tmp;t=(s[i]+s[j])%6;Data[k] ^= s[t];}}//加解密函数//puttext(char filename[],char *ch){if((fp=fopen(filename2,"w"))==NULL) printf("打开错误!\n\n"); fputs(ch,fp); fclose(fp); exit(0);}gettext(char filename[]){ if((fp=fopen(filename,"rt"))==NULL) printf("打开错误!\n\n"); ch1=fgetc(fp); while(ch1!=EOF) ch1=fgetc(fp); printf("\n\n"); fclose(fp); fp=fopen(filename,"r"); fgets(ch,MAX,fp); fclose(fp); printf("\n"); printf("文件打开完成!\n\n");}//文件输入输出函数//int main(){ unsigned char s[256] = {0},s2[256] = {0}; //S-box char key[256]; int i,n; ULONG len; printf("请输入密钥:\n"); gets(key); printf("请输入数字选择相应功能:\n"); printf("**************************\n"); printf("1------加密文件。\n"); printf("2------解密文件。\n"); printf("3------动态输入。\n"); printf("0------退出。\n"); printf("**************************\n"); scanf("%d",&n); if(n==0) { printf("谢谢使用!再见!\n"); exit(0); system("pause"); } else if(n>3) { printf("输入错误!\n"); exit(0); } printf("key = %s, length = %d\n\n",key,strlen(key)); rc4_init(s,(unsigned char *)key,strlen(key)); //已经完成了初始化 printf("完成对S[i]的初始化!"); printf("\n\n"); for(i=0;i<256;i++)//用s2[i]暂时保留经过初始化的s[i] s2[i]=s[i]; printf("请输入需要加(解)密文件的路径及文件名:"); scanf("%s",filename1); printf("\n\n"); switch(n) { case 1: { gettext(filename1); len=strlen(ch); printf("文件内容为%s;\n长度为%d。\n\n",ch,len); printf("已经初始化,现在加密:\n\n"); rc4_crypt(s,(unsigned char *)ch,len);//加密 printf("加密后的内容为%s\n\n",ch); printf("请输入输出文件地址和名称:"); scanf("%s",filename2); puttext(filename2,ch); printf("文件输出完毕!"); } case 2: { gettext(filename1); len = strlen(ch); printf("现在解密:\n"); rc4_init(s,(unsigned char *)key, strlen(key)); //初始化 rc4_crypt(s2,(unsigned char *)ch,len);//解密 printf("解密后的内容为%s\n\n",ch); printf("请输入输出文件地址和名称:"); scanf("%s",filename2); puttext(filename2,ch); printf("文件输出完毕!"); } case 3: { printf("请输入加密内容:\n"); scanf("%s",ch); len=strlen(ch); printf("输入内容为%s;\n长度为%d。\n\n",ch,len); printf("已经初始化,现在加密:\n\n"); rc4_crypt(s,(unsigned char *)ch,len);//加密 printf("加密后的内容为%s\n\n",ch); printf("现在解密:\n"); rc4_init(s,(unsigned char *)key, strlen(key)); //初始化 rc4_crypt(s2,(unsigned char *)ch,len);//解密 printf("解密后的内容为%s\n\n",ch); } } return 0;}
阅读全文
0 0
- RC4
- RC4
- RC4
- rc4
- RC4
- RC4 加密
- RC4加密算法
- RC4算法
- RC4算法
- Openssl-rc4
- RC4算法
- rc4加密算法
- RC4加密
- RC4加密算法
- RC4加密算法
- RC4加密
- RC4算法
- RC4加密算法
- jquery ajax请求成功,返回了数据,但是不进success的问题
- [BZOJ 4565][HAOI 2016] 字符合并 状压DP+区间DP
- 状态模式
- 找含有49的个数
- TensorFlow学习日记20
- RC4
- 『0005』- 以太坊智能合约生命周期(Ethereum smart contracts lifecycle)
- Java程序性能优化 读书笔记(九)优化组件:池
- 怎样完全卸载tensorflow?
- 数组、链表和哈希表
- jsp+servlet(4)
- 8254定时/计数器实验
- 【JZOJ5430】图
- 函数的调用过程(栈帧)