rc4算法簡單介紹及實現

0. 介紹

RC4是一種流密碼,但因為安全性問題已經被棄用。

1. 算法描述

1.1 初始化

Key為生成的隨機密鑰:1-256B
S為一數組:256B
T為輔助數組:keylenB

for (int i = 0;i < 256;i++) {S[i] = i;T[i] = S[i % keylen];
}
1.2 初始化排列

通過下面的過程來,初始化排列S

int j = 0;
for (int i = 0;i < 256;i++) {j = (j + S[i] + key[i%key_len]) % 256;int tmp = S[i];S[i]    = S[j];S[j]    = tmp;
}
1.3 流生成

生成好排列后,就可以根據排列,重復生成key進行加解密操作了。

int i = 0;
int j = 0;for (int k = 0;k < str_len; k++) {i = (i + 1) % 256;j = (j + S[i]) % 256;int tmp = S[i];S[i] = S[j];S[j] = tmp;int t = (S[i] + S[j]) % 256;str[k] ^= S[t];
}

3. 代碼

實現見ltnotfty-gitee

參考

william stallings
manojpandey-rc4

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/bicheng/73513.shtml
繁體地址,請注明出處:http://hk.pswp.cn/bicheng/73513.shtml
英文地址,請注明出處:http://en.pswp.cn/bicheng/73513.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

OpenEuler20.3 安裝 Elasticsearch7.17

1、下載elasticsearch wget https://artifacts.elastic.co/downloads/elasticsearch/elasticsearch-7.17.17-linux-x86_64.tar.gz wget https://artifacts.elastic.co/downloads/elasticsearch/elasticsearch-7.17.17-linux-x86_64.tar.gz.sha512 shasum -a 512 -c elasticsea…

單元測試知識總結

&#x1f345; 點擊文末小卡片 &#xff0c;免費獲取軟件測試全套資料&#xff0c;資料在手&#xff0c;漲薪更快 一、什么是單元測試&#xff1f; 單元測試是指&#xff0c;對軟件中的最小可測試單元在與程序其他部分相隔離的情況下進行檢查和驗證的工作&#xff0c;這里的…

python爬蟲筆記(一)

文章目錄 html基礎標簽和下劃線無序列表和有序列表表格加邊框 html的屬性a標簽&#xff08;網站&#xff09;target屬性換行線和水平分割線 圖片設置寬高width&#xff0c;height html區塊——塊元素與行內元素塊元素與行內元素塊元素舉例行內元素舉例 表單from標簽type屬性pla…

【mysql】centOS7安裝mysql詳細操作步驟!—通過tar包方式

【mysql】centOS7安裝mysql詳細操作步驟&#xff01; linux系統安裝mysql版本 需要 root 權限&#xff0c;使用 root 用戶進行命令操作。使用tar文件包&#xff0c;安裝&#xff0c;gz包也可以但是還需要配置用戶&#xff0c;tar包雖然大&#xff0c;但是全啊&#xff01; 1. …

[新能源]新能源汽車快充與慢充說明

接口示意圖 慢充接口為交流充電口&#xff08;七孔&#xff09;&#xff0c;快充接口為直流充電口&#xff08;九孔&#xff09;。 引腳說明 上圖給的是充電口的引腳圖&#xff0c;充電槍的為鏡像的。 慢充接口引腳說明 快充接口引腳說明 充電流程 慢充示意圖 慢充&…

Android第二次面試總結(項目拷打理論篇)

&#xff08;一&#xff09;理論基礎 LiveData 和 ViewModel 是 Android 架構組件中的重要部分&#xff0c;它們在構建響應式、生命周期感知的 Android 應用程序中發揮著關鍵作用。下面分別介紹它們的原理。 LiveData 原理 1. 概述 LiveData 是一種可觀察的數據持有者類&…

MyBatis SqlSessionFactory 是如何創建的?

SqlSessionFactory 是 MyBatis 的核心接口之一&#xff0c;它是創建 SqlSession 實例的工廠。 SqlSession 實例是 MyBatis 與數據庫交互的主要接口&#xff0c;負責執行 SQL 語句、管理事務等。 SqlSessionFactory 的創建過程主要由 SqlSessionFactoryBuilder 類負責。 SqlSes…

玩轉python:通俗易懂掌握高級數據結構-collections模塊之Counter

引言 Counter是Python中collections模塊提供的一個強大工具&#xff0c;用于統計可哈希對象的出現次數。它非常適合用于頻率統計、詞頻分析、數據聚合等場景。本文將詳細介紹Counter的關鍵用法和特性&#xff0c;并通過8個豐富的案例幫助讀者掌握其應用。 關鍵用法和特性表格 …

DeepSeek面試——分詞算法

DeepSeek-V3 分詞算法 一、核心算法&#xff1a;字節級BPE&#xff08;Byte-level BPE&#xff0c;BBPE&#xff09; DeepSeek-V3 采用 字節級BPE&#xff08;BBPE&#xff09; 作為核心分詞算法&#xff0c;這是對傳統 BPE&#xff08;Byte Pair Encoding&#xff09;算法的…

機器學習——正則化、欠擬合、過擬合、學習曲線

過擬合&#xff08;overfitting&#xff09;:模型只能擬合訓練數據的狀態。即過度訓練。 避免過擬合的幾種方法&#xff1a; ①增加全部訓練數據的數量&#xff08;最為有效的方式&#xff09; ②使用簡單的模型&#xff08;簡單的模型學不夠&#xff0c;復雜的模型學的太多&am…

Python:函數(一)

python函數相關的知識點 1. 函數定義與調用 定義&#xff1a;使用 def 關鍵字&#xff0c;后接函數名和參數列表。 def greet(name):"""打印問候語&#xff08;文檔字符串&#xff09;"""print(f"Hello, {name}!") 調用&#xff1a…

關于Flutter中兩種Widget的生命周期詳解

目錄 一、StatelessWidget 生命周期 二、StatefulWidget 生命周期 1. 創建階段 2. State初始化階段 3. 構建階段 4. 更新階段 5. 銷毀階段 三、核心對比與常見陷阱 四、面試回答技巧 以下是Flutter中兩種核心Widget(StatelessWidget和StatefulWidget)生命周…

Linux 》》Ubuntu 18 LTS 之后的版本 修改IP地址 主機名

進入目錄 /etc/netplan 修改 50-cloud-init.yaml 》保存文件后&#xff0c;執行以下命令應用更改&#xff1a; sudo netplan apply 》》 DHCP模式 修改主機名 hostnamectl set-hostname xxxx 修改cloud.cfg 防止重啟主機名還原 但測試下來 不修改&#xff0c; 重啟 也不會還…

C++基礎 [三] - 面向對象三

初始化列表 首先&#xff0c;初始化列表是我們的祖師爺本賈尼博士為了解決在某些成員變量在定義時必須初始化的情況。這個初始化列表其實發生在構造函數之前&#xff0c;也就是實例化整個對象時先對所有的成員都進行了初始化 初始化的概念區分 在之前的博客學習中&#xff…

55年免費用!RevoUninstaller Pro專業版限時領取

今天&#xff0c;我要給大家介紹一款超給力的卸載工具——RevoUninstaller Pro。這是一款由保加利亞團隊精心打造的專業級卸載軟件&#xff0c;堪稱軟件卸載界的“神器”。 RevoUninstaller分為免費版和專業版。專業版功能更為強大&#xff0c;但通常需要付費才能解鎖全部功能。…

目前人工智能的發展,判斷10年、20年后的人工智能發展的主要方向,或者帶動的主要產業

根據2025年的最新行業研究和技術演進趨勢&#xff0c;結合歷史發展軌跡&#xff0c;未來10-20年人工智能發展的主要方向及帶動的產業將呈現以下六大核心趨勢&#xff1a; 一、算力革命與底層架構優化 核心地位&#xff1a;算力將成為類似“新能源電池”的基礎設施&#xff0c;…

【機器人】復現 ASGrasp 通用透明物體重建、6-DoF抓取預測

在機器人抓取領域&#xff0c;透明和鏡面物體的抓取一直是個難題。 ASGrasp核心是兩層學習型立體網絡&#xff0c;能夠同時恢復透明和鏡面物體的可見部分和不可見部分的深度信息。 然后融合兩層深度信息&#xff0c;進行重建物體&#xff0c;得到點云信息作為GSNet&#xff0…

2. qt寫帶有槽的登錄界面(c++)

我們在1.Qt寫簡單的登錄界面(c)_c qt 設計一個簡單界面-CSDN博客中寫了個簡單的登錄界面&#xff0c;但沒有槽&#xff0c;在這里寫一個帶有槽的界面。 1.代碼 代碼目錄如下&#xff1a; main.cpp的代碼如下&#xff1a; #include "MainWindow.h" #include <Qt…

windows安裝兩個或多個JDK,并實現自由切換

我用兩個JDK來做演示&#xff0c;分別是JDK8和JDK17(本人已安裝JDK8&#xff0c;所以這里只演示JDK17的安裝)。 1、下載JDK17安裝 Java Downloads | Oracle 2、安裝JDK17,這里忽略。直接雙擊軟件&#xff0c;點擊下一步就可以。 3、配置環境變量 在系統變量中新建一個CLASSP…

【2025最新】深度學習框架PyTorch——從入門到精通(1)下載與安裝

又名&#xff1a;蕪湖起飛俠的PyTorch學習記錄——從起飛到墜毀 簡介安裝內容總覽安裝AnacondaAnaconda簡介Anaconda下載配置環境變量驗證其他配置安裝matplotlib 安裝 CUDA安裝之前安裝cuDNN 安裝torchCPU 版本安裝GPU 版本安裝通過pip安裝&#xff08;不推薦&#xff09;通過…