RC4算法解析

RC4是由RSA Security的罗纳德·李维斯特在1987年开发出来的,虽然它的官方名是“Rivest Cipher 4”,但是首字母缩写RC也可以理解为"Ron’s Code"。

RC4加解密原理

加解密分为两个步骤:密钥的初始化和加解密。

初始化:

用初始密钥打乱sbox的顺序,代码比较简单,暂不赘叙。

加解密:

  1. 每次加(解)密一段数据时,取出密钥第一个字节,把该字节当作索引,从密钥中取出对应的字节值,并保留该字节为N,并在密钥中交换这两个字节。
  2. 计算这两个字节的和
  3. 从要加(解)密的数据中,取出一个字节。
  4. 上述两个字节异或,实现加解密效果
  5. 取出密钥的第二个字节,加上字节N当作索引,加解密的数据的第二个字节,继续上述循环。

从对源码的分析可以得出结论:

  1. RC4时时动态变化的,并且,对加解密双方来说是实时保持一致的,这是一个巨大的优点。
  2. 计算简单,速度快。
    鉴于这两个原因,该算法是https/SSL等最优先采用的加解密方式。

但是,从最近这些年的披露信息看,该算法似乎存在安全风险。

传统代码中,RC4一般采用256字节长度的密钥,我个人觉得,增加密钥长度,应该有助于加强RC4的安全性,因此代码中将密钥长度改为1024字节(这个长度可以任意调整)。

代码如下:

#include<stdio.h>
#include<string.h>
#include "rc4.h"#define KEY_SIZE 1024/*初始化函数*/
void rc4_init(unsigned char* s, unsigned char* key, unsigned long Len)
{int i = 0, j = 0;char k[KEY_SIZE] = { 0 };unsigned char tmp = 0;for (i = 0; i < KEY_SIZE; i++){s[i] = i;k[i] = key[i % Len];}for (i = 0; i < KEY_SIZE; i++){j = (j + s[i] + k[i]) % KEY_SIZE;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++){j = (j + s[i]) % KEY_SIZE;tmp = s[i];s[i] = s[j];//交换s[x]和s[y]s[j] = tmp;t = (s[i] + s[j]) % KEY_SIZE;Data[k] ^= s[t];i = (i + 1) % KEY_SIZE;}
}int rc4_test()
{unsigned char s[KEY_SIZE] = { 0 }, s2[KEY_SIZE] = { 0 };//S-boxchar key[KEY_SIZE] = { "this is the key to init RC4 key" };char pData[512] = "[Data]这是一段用来测试RC4加解密算法的数据,此段数据会被用来加密和解密、并被输出显示、以便验证RC4加解密算法的正确性[Data]";unsigned long datalen = strlen(pData);printf("加解密测试数据:\"%s\"\n\n", pData);printf("RC4密钥:\"%s\",长度:%d\n\n", key, strlen(key));rc4_init(s, (unsigned char*)key, strlen(key));printf("S-box初始化数据:\r\n");for (int i = 0; i < KEY_SIZE; i++){printf("%02X", s[i]);if (i && (i + 1) % 16 == 0)putchar('\n');}printf("\n\n");for (int i = 0; i < KEY_SIZE; i++)//用s2[i]暂时保留经过初始化的s[i]{s2[i] = s[i];}rc4_crypt(s, (unsigned char*)pData, datalen);//加密printf("RC4加密后的数据:%s\r\n\r\n", pData);rc4_init(s2,(unsigned char*)key,strlen(key));//初始化密钥rc4_crypt(s2, (unsigned char*)pData, datalen);//解密printf("RC4解密后的数据:%s\r\n\r\n", pData);return 0;
}

参考链接:

  1. https://baike.baidu.com/item/RC4/3454548
  2. https://zh.wikipedia.org/wiki/RC4

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/594655.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【面试高频算法解析】算法练习2 回溯

目录 前言算法解析练习题组合总和全排列II单词搜索 前言 本篇章开放目的是按算法类型学习算法&#xff0c;学习对应算法理论&#xff0c;并通过练习一些经典算法题深入理解这类算法&#xff0c;避免出现刷了很多算法题&#xff0c;还是一知半解的状态 算法解析 回溯&#xff…

es 简单集群搭建,版本8.6.2

Node-1 配置&#xff1a; # elasticsearch.yml for Node-1cluster.name: my-test-cluster node.name: node-1 path.data: /path/to/data/node-1 path.logs: /path/to/logs/node-1 network.host: 127.0.0.1 http.port: 9200 transport.port: 9300 discovery.seed_hosts: ["…

Canal+RabbitMQ实现MySQL数据同步至ClickHouse

ClickHouse作为一个被广泛使用OLAP分析引擎&#xff0c;在执行分析查询时的速度优势很好的弥补了MySQL的不足&#xff0c;但是如何将MySQL数据同步到ClickHouse就成了用户面临的第一个问题。本文利用Canal来实现ClickHouse实时同步MySQL数据&#xff0c;使用RabbitMQ来做消息队…

FreeRTOS——计数型信号量知识总结及实战

1计数型信号量概念 1&#xff09;计数型信号量相当于队列长度大于1 的队列&#xff0c;因此计数型信号量能够容纳多个资源 2&#xff09;适用场景&#xff1a; 事件计数&#xff1a; 当每次事件发生后&#xff0c;在事件处理函数中释放计数型信号量&#xff08;计数值1&#x…

【C语言】汉诺塔问题/数据结构经典问题/详细总结讲解

1. 前言 汉诺塔问题是一个经典的递归问题&#xff0c;源于印度的一个古老传说。这个问题的特点是其独特的解决方式&#xff0c;需要将一堆盘子从一个柱子移动到另一个柱子&#xff0c;每次只能移动一个盘子&#xff0c;并且不能将一个较大的盘子放在较小的盘子上面。这个问题的…

MySQL存储引擎InnoDB和MyISAM的区别?

MySQL存储引擎InnoDB和MyISAM的区别? InnoDB和MyISAM是MySQL数据库两种常见的存储引擎&#xff0c;它们在性能、事务支持等方面有一些重要的区别。以下是它们的一些主要区别&#xff1a; 事务支持&#xff1a; InnoDB&#xff1a; 支持事务&#xff0c;具有ACID&#xff08;原…

Go语言开发IDE全面分析

Go语言开发IDE全面分析 Go语言&#xff0c;又称为Golang&#xff0c;是Google开发的一种静态类型、编译型语言&#xff0c;它具有简洁、快速、安全、并发等特点。作为一名高效的Go语言程序员&#xff0c;选择一个功能强大的集成开发环境&#xff08;IDE&#xff09;是至关重要…

在Docker中安装Tomact

目录 前言&#xff1a; 一.安装Tomact 查找指定的tomact版本 下载tomact9.0 查看该镜像是否安装成功 安装成功之后就开始运行镜像了 ps&#xff08;用于列出正在运行的Docker容器&#xff09; ​编辑 测试(虚拟机ip:8080) ​编辑 解决措施 ​编辑 完成以上步骤&…

如何将本文中的表情符号,使用正则表达式pattern,匹配并替换

如下面的文本: xxxxx \uD83E\uDD1F xxxxx 🤟 xxxxx \uD83E\uDD1Fxxxxx 🤟如何替换这些特殊的unicode呢? 我们先学习下常见的正则: 基本的 Unicode 属性分类 \p{L}|\p{Letter} 字母 \p{M}|\p{Mark

技术学习|CDA level I 描述性统计分析(统计学概述)

统计学是一门收集、处理、分析、解释数据&#xff0c;并从中得出结论的科学。 研究思路&#xff1a;收集数据——>处理数据——>分析数据——>解释数据 收集数据是数据分析的前提&#xff0c;传统的数据收集方法包括两个来源&#xff1a;直接来源和间接来源&#xff…

LabVIEW在高精度机器人视觉定位系统中的应用

在现代工业自动化中&#xff0c;精确的机器人视觉定位系统对于提高生产效率和产品质量至关重要。LabVIEW软件&#xff0c;以其卓越的图像处理和自动化控制功能&#xff0c;在这一领域发挥着重要作用。本案例将展示LabVIEW如何帮助开发和实现一个高精度的机器人视觉定位系统&…

有什么安全处理方案可以有效防护恶意爬虫

常见的爬虫 有百度爬虫、谷歌爬虫、必应爬虫等搜索引擎类爬虫&#xff0c;此类爬虫经常被企业用于提高站点在搜索引擎内的自然排名&#xff0c;使得站点在各大搜索引擎中的排名能够提高&#xff0c;进一步通过搜索引擎来进行引流为企业增加业务流量。 恶意爬虫与合法、合规的搜…

Web自动化测试框架总结

实施过了web系统的UI自动化&#xff0c;回顾梳理下&#xff0c;想到什么写什么&#xff0c;随时补充。 首先&#xff0c;自动化测试不是手动测试的替代品&#xff0c;是比较好的补充&#xff0c;而且不是占大比重的补充。 70%的测试工作集中在底层接口测试和单元测试&#xff0…

多元统计分析(4):判别分析

4.1 判别分析的目标 主要目的&#xff1a;判别一个个体所属类别 4.2 距离判别 都选用用马氏距离 4.2.1 判别准则 化简的证明&#xff1a; 称为判别函数&#xff0c;为判别系数。 4.2.2 误判概率 【1】当两个正态总体的协方差相同 证明&#xff1a; 当两个正态总体重合的时…

uniapp中组件库丰富的Switch 开关选择器使用方法

目录 #平台差异说明 #基础使用 #加载中 #禁用switch #自定义尺寸 #自定义颜色 #自定义样式 #异步控制 API #Switch Props #Switch Event 选择开关用于在打开和关闭状态之间进行切换。 #平台差异说明 App&#xff08;vue&#xff09;App&#xff08;nvue&#xff0…

学生公寓安全用电管理系统应用案例

摘要&#xff1a;安全用电是学校公寓用电管理的首要任务&#xff0c;这就需要对一些恶性负载进行识别和控制&#xff0c;同时为了减少电工和后期管理人员的成本&#xff0c;引进了安全用电管理系统。本文在在描述了安全用电管理系统的工作原理和利用智能电表可实现的功能后,阐明…

数字信号处理期末复习——基础知识汇总(三)

个人名片&#xff1a; &#x1f981;作者简介&#xff1a;一名喜欢分享和记录学习的在校大学生 &#x1f42f;个人主页&#xff1a;妄北y &#x1f427;个人QQ&#xff1a;2061314755 &#x1f43b;个人邮箱&#xff1a;2061314755qq.com &#x1f989;个人WeChat&#xff1a;V…

基于ssm的小儿肺炎知识管理系统设计与实现+vue论文

小儿肺炎知识管理系统设计与实现 摘要 当下&#xff0c;正处于信息化的时代&#xff0c;许多行业顺应时代的变化&#xff0c;结合使用计算机技术向数字化、信息化建设迈进。传统的信息管理模式&#xff0c;采用人工登记的方式保存相关数据&#xff0c;这种以人力为主的管理模式…

单机多进程,每个进程多张卡 mpi nccl 程序设计检验

做了部分注释&#xff0c;比较乱 本示例结构&#xff1a; 1&#xff0c;源代码 #include <stdlib.h> #include <stdio.h> #include "cuda_runtime.h" #include "nccl.h" #include "mpi.h" #include <unistd.h> #include <…

网络安全—模拟IP代理隐藏身份

文章目录 网络拓扑安装使用代理服务器设置隐藏者设置 使用古老的ccproxy实现代理服务器&#xff0c;仅做实验用途&#xff0c;禁止做违法犯罪的事情&#xff0c;后果自负。 网络拓扑 均使用Windows Server 2003系统 Router 外网IP&#xff1a;使用NAT模式 IP DHCP自动分配或者…