openssl源碼分析之加密模式(modes)

openssl實現分組加密模式(例如AES128-CBC的CBC部分)的模塊名字叫做modes,源代碼位于

https://gitee.com/gh_mirrors/openssl/tree/master/crypto/modes
博主又打不開github了TT,只能找個gitee鏡像

頭文件是modes.h。

該模塊目前支持12種加密模式,如圖,每一個文件就是一個模式。

加密模式與加密算法并不綁定,你可以使用自定義的加密函數,只要分組長度是128bit即可。理論上可以使用非對稱的加密函數,但必須是128bit等長分組,這種情況并不常見。

以CRYPTO_cbc128_encrypt為例,該函數的最后一個參數是一個函數指針,用于對一個分組進行加密,需要調用者提供。

void CRYPTO_cbc128_encrypt(const unsigned char *in, unsigned char *out,size_t len, const void *key,unsigned char ivec[16], block128_f block)
{size_t n;const unsigned char *iv = ivec;if (len == 0)return;#if !defined(OPENSSL_SMALL_FOOTPRINT)if (STRICT_ALIGNMENT &&((size_t)in | (size_t)out | (size_t)ivec) % sizeof(size_t) != 0) {while (len >= 16) {for (n = 0; n < 16; ++n)out[n] = in[n] ^ iv[n];(*block) (out, out, key);iv = out;len -= 16;in += 16;out += 16;}} else {while (len >= 16) {for (n = 0; n < 16; n += sizeof(size_t))*(size_t_aX *)(out + n) =*(size_t_aX *)(in + n) ^ *(size_t_aX *)(iv + n);(*block) (out, out, key);iv = out;len -= 16;in += 16;out += 16;}}
#endifwhile (len) {for (n = 0; n < 16 && n < len; ++n)out[n] = in[n] ^ iv[n];for (; n < 16; ++n)out[n] = iv[n];(*block) (out, out, key);iv = out;if (len <= 16)break;len -= 16;in += 16;out += 16;}if (ivec != iv)memcpy(ivec, iv, 16);
}

注意事項:

1、block參數必須支持前2個參數使用相同的指針,即輸入輸出使用同一塊緩存。

2、key參數沒有長度限制,實際長度取決于block。因此受限制的是分組長度而非密鑰長度,密鑰長度可以不等于分組長度,AES256就是這種情況。

對于GCM這種較為復雜的模式,需要輸入上下文對象指針。

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

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

相關文章

Java 搭建 MC 1.18.2 Forge 開發環境

推薦使用 IDEA 插件 Minecraft Development 進行創建項目 創建完成后即可進行 MOD 開發。 但是關于 1.18.2 的開發教程太少&#xff0c;因此自己研究了一套寫法&#xff0c;寫法并非是最優的但是是探索開發MOD中的一次筆記和記錄 GITHUB: https://github.com/zimoyin/zhenfa…

nginx如何實現負載均衡?

Nginx 是一款高性能的 Web 服務器和反向代理服務器&#xff0c;它可以通過配置實現負載均衡功能。以下是實現負載均衡的詳細步驟和方法&#xff1a; 1. 基本概念 負載均衡是將客戶端請求分發到多個后端服務器上&#xff0c;以提高系統的可用性和性能。Nginx 支持多種負載均衡策…

深度學習天崩開局

李沐大神的d2l包導入&#xff0c; 這玩意需要python311版本&#xff0c;我現在版本已經313了&#xff0c;作為一個天生要強的男人&#xff0c;我是堅決不向低版本低頭的。 然后我就研究啊&#xff0c;各種翻資料啊&#xff0c;然后deepseek加豆包都翻爛了&#xff0c; 最終所…

docker部署jenkins并成功自動化部署微服務

一、環境版本清單&#xff1a; docker 26.1.4JDK 17.0.28Mysql 8.0.27Redis 6.0.5nacos 2.5.1maven 3.8.8jenkins 2.492.2 二、服務架構&#xff1a;有gateway&#xff0c;archives&#xff0c;system這三個服務 三、部署步驟 四、安裝linux 五、在linux上安裝redis&#…

MPDrive:利用基于標記的提示學習提高自動駕駛的空間理解能力

25年4月來自南方科技大學、百度、英國 KCL和琶洲實驗室&#xff08;廣東 AI 和數字經濟實驗室&#xff09;的論文“MPDrive: Improving Spatial Understanding with Marker-Based Prompt Learning for Autonomous Driving”。 自動駕駛視覺問答&#xff08;AD-VQA&#xff09;…

Halcon圖像采集

Halcon是一款強大的機器視覺軟件&#xff0c;結合C#可以開發出功能完善的視覺應用程序。 基本設置 確保已經安裝了Halcon和Halcon的.NET庫&#xff08;HalconDotNet&#xff09;。 1. 添加引用 在C#項目中&#xff0c;需要添加對HalconDotNet.dll的引用&#xff1a; 右鍵點…

Win10定時任務計劃無法顯示要執行的EXE任務程序界面,問題解決辦法

用C#開發的一款WINFORM程序&#xff0c;在電腦測試一切順利&#xff0c;運行結果正確。但用電腦的定時任務執行時&#xff0c;程序界面不顯示&#xff0c;重啟電腦、各種試都不行&#xff0c;最終問題解決。 解決辦法&#xff1a; 要選“只在用戶登陸時運行”&#xff0c;才能執…

Navicat和PLSQL在oracle 使用語句報ORA-00911: 無效字符

后面我發現可能是在復制SQL語句中有中文&#xff0c;但是環境變量未配置中文環境。 因為Oracle的語法解析器特別嚴格&#xff0c;就會報出以上的錯誤出來。 SQL語句錯誤&#xff0c;存在中文字符或者sql語句空格導致&#xff0c;去掉即可解決。 我重新寫語句&#xff0c;發現…

[ctfshow web入門] web30

信息收集 題目將flag system php不區分大小寫地過濾了 解題 前置知識 print_r&#xff1a;php中用于打印數組 scandir&#xff1a;php中用于獲取指點目錄下的所以文件目錄名 getcwd&#xff1a;獲取當前目錄 目錄獲取 這里提供兩種方法 print_r(scandir(getcwd())); pri…

linux下MMC_TEST的使用

一:打開如下配置,將相關文件編譯到內核里: CONFIG_MMC_TEST CONFIG_MMC_DEBUG CONFIG_DEBUG_FS二:將mmc設備和mmc_test驅動進行綁定 2.1查看mmc設備編號 ls /sys/bus/mmc/drivers/mmcblk/mmc0:aaaa2.2將mmc設備與原先驅動進行解綁 echo mmc0:aaaa >

《深度解析LightGBM與MySQL數據集成:高效機器學習的新范式》

在機器學習工程實踐中&#xff0c;數據與模型的高效交互一直是制約算法性能發揮的關鍵瓶頸。LightGBM作為梯度提升決策樹框架的杰出代表&#xff0c;其與關系型數據庫MySQL的深度集成能力&#xff0c;為數據科學家提供了從原始數據到預測結果的完整解決方案。這種集成不是簡單的…

處理Excel的python庫openpyxl、xlrd、xlwt、pandas有什么區別,搞懂它

openpyxl、xlrd、xlwt、pandas 都能處理 Excel 表格&#xff0c;但用途和適合的場景不同。今天做個總結&#xff1a; 庫名功能支持格式讀寫支持樣式備注openpyxl全面的.xlsx處理庫.xlsx&#xff08;Excel2007&#xff09;???首選xlrd讀取.xls文件的老牌工具.xls&#xff08…

EasyExcel-一款好用的excel生成工具

EasyExcel是一款處理excel的工具類&#xff0c;主要特點如下&#xff08;官方&#xff09;&#xff1a; 特點 高性能讀寫&#xff1a;FastExcel 專注于性能優化&#xff0c;能夠高效處理大規模的 Excel 數據。相比一些傳統的 Excel 處理庫&#xff0c;它能顯著降低內存占用。…

視頻分析設備平臺EasyCVR攜手高空拋物AI智能分析技術,打造住宅小區頭頂安全智能防線

一、背景介紹 隨著城市化進程的高速推進&#xff0c;城市天際線不斷被刷新&#xff0c;高樓大廈密密麻麻。然而&#xff0c;高空拋物問題也逐漸顯現&#xff0c;這一行為不僅嚴重影響城市文明的形象&#xff0c;更帶來很多安全隱患&#xff0c;威脅居民的生命財產安全&#xf…

Spring MVC 操作會話屬性詳解(@SessionAttributes 與 @SessionAttribute)

Spring MVC 操作會話屬性詳解&#xff08;SessionAttributes 與 SessionAttribute&#xff09; 1. 核心注解對比 注解作用范圍功能SessionAttributes類級別聲明控制器中需要持久化的模型屬性&#xff08;存入 HttpSession&#xff09;SessionAttribute方法參數/返回值顯式綁定…

Python字典實戰: 三大管理系統開發指南(班級+會議+購物車)(附源碼)

目錄 摘要 一、班級管理系統&#xff08;含成績模塊&#xff09; 1. 功能概述 2. 完整代碼與解析 3. 代碼解析與亮點 二、會議管理系統 1. 功能概述 2. 完整代碼 3. 代碼解析與亮點 三、購物車管理系統 1. 功能概述 2. 完整代碼 3. 代碼解析與亮點 四、總結與擴…

北京自在科技:讓萬物接入蘋果Find My網絡的″鑰匙匠″

在AirTag掀起全球防丟熱潮的今天&#xff0c;越來越多的第三方產品開始接入蘋果Find My網絡——從充電寶到電動車&#xff0c;從行李箱到保溫杯&#xff0c;用戶只需打開iPhone的「查找」App&#xff0c;就能實時定位這些物品。 北京自在科技有限責任公司早在蘋果推出Find My開…

Vue進行前端開發流程

一、創建vue項目 創建vue項目&#xff1a;先進入要操作的目錄下&#xff0c;注意本項目是用vue2開發的。 vue create vue項目名 二、項目開發 1.創建項目結構 2.開發功能模塊 主入口App.vue <template><div class"boss-app"><Header /><m…

網絡帶寬測速工具選擇指南iperf3 nttcp tcpburn jperf使用詳解

簡介 本文主要介紹內網&#xff08;局域網&#xff09;與外網&#xff08;互聯網&#xff09;的網絡帶寬測速工具下載地址、選擇指南、參數對比、基本使用。 測速工具快速選擇指南 測速工具下載地址 iperf 官網下載鏈接&#xff1a;iperf.fr/iperf-download.php該鏈接提供了不…

微軟的 Copilot 現在可以瀏覽網頁并為您執行操作

在慶祝其 50 歲生日之際&#xff0c;微軟正在向其人工智能驅動的 Copilot 聊天機器人傳授一些新技巧。 從 BASIC 到 AI&#xff0c;改變世界的公司&#xff1a;微軟 微軟表示&#xff0c;Copilot 現在可以在“大多數網站”上采取行動&#xff0c;使其能夠預訂門票、預訂餐廳等…