当前位置: 首页 > article >正文

基于AES的图像加解密算法matlab仿真,带GUI界面

目录

1.程序功能描述

2.测试软件版本以及运行结果展示

3.核心程序

4.本算法原理

4.1 加密过程

4.2 解密过程

5.完整程序


1.程序功能描述

        基于AES的图像加解密算法matlab仿真,带GUI界面。在GUI界面上进行操作,分别对图像进行AES加密,AES解密。

2.测试软件版本以及运行结果展示

MATLAB2022A版本运行

(完整程序运行后无水印)

3.核心程序



% --- Executes on button press in pushbutton3.
function pushbutton3_Callback(hObject, eventdata, handles)
% hObject    handle to pushbutton3 (see GCBO)
% eventdata  reserved - to be defined in a future version of MATLAB
% handles    structure with handles and user data (see GUIDATA)
global Image_RGB;
global SBOX;
global invSBOX;
global w;
global polys;
global invpolys;
global images_AES;

[rr,cc] = size(Image_RGB);
%   ܴ   
for i = 1:rr/16
    for j = 1:cc
        images_deAES{i,j} = func_invAES(images_AES{i,j},w,invSBOX,invpolys,1);
    end
end 
%  ʾ   ܺ  ͼ  
for i = 1:rr/16
    for j = 1:cc
        tmp                             = (images_deAES{i,j})';
        iamges_deaes(16*(i-1)+1:16*i,j) = double(tmp);
    end
end

axes(handles.axes3);
imshow(iamges_deaes,[]);


%    PSNR
[psnr,mse] = func_PSNR(Image_RGB,iamges_deaes)





% --- Executes on button press in pushbutton4.
function pushbutton4_Callback(hObject, eventdata, handles)
% hObject    handle to pushbutton4 (see GCBO)
% eventdata  reserved - to be defined in a future version of MATLAB
% handles    structure with handles and user data (see GUIDATA)
clc;
clear;
close all;
29_001m

4.本算法原理

       AES是一种块加密算法,这意味着它处理固定长度的数据块。对于AES而言,块大小固定为128位(16字节),而密钥长度可以是128位、192位或256位。AES的工作流程包括多个轮次的替代和置换操作,这些操作增强了数据的安全性。

4.1 加密过程

AES的加密过程可以总结为以下几个步骤:

  1. 初始轮(Initial Round)

    • 将明文块与密钥通过XOR运算进行混合。
  2. 主循环(Main Loop)

    • 字节替换(SubBytes):每个字节被替换为其S-box中的对应值。S-box是一个非线性替换表,用于增加算法的复杂度。
    • 行移位(ShiftRows):每一行的数据按照一定的规则向左或向右移动。
    • 列混淆(MixColumns):每列的数据通过矩阵乘法进行混合。这一步骤确保了不同列之间的数据交互。
    • 密钥加(AddRoundKey):将轮密钥与状态矩阵进行XOR操作。
  3. 最终轮(Final Round)

    • 这一轮不包括列混淆步骤,其余步骤与主循环相同。

4.2 解密过程

解密过程是加密过程的逆向操作。具体步骤如下:

  1. 初始轮(Initial Round)

    • 进行AddRoundKey操作。
  2. 主循环(Main Loop)

    • 密钥加(AddRoundKey)
    • 列逆混淆(InvMixColumns):使用特定的逆矩阵代替MixColumns中的矩阵。
    • 行逆移位(InvShiftRows):与ShiftRows相反的操作。
    • 字节逆替换(InvSubBytes):使用逆S-box替换字节。
  3. 最终轮(Final Round)

    • 进行AddRoundKey操作后,执行InvShiftRows和InvSubBytes。

5.完整程序

VVV


http://www.kler.cn/news/292939.html

相关文章:

  • 20240905软考架构-------软考126-130答案解析
  • 我在高职教STM32——ADC电压采集与光敏电阻(5)
  • 【项目日记】高并发内存池---实现页缓存
  • 【JAVA基础】StringUtils.isEmpty、StringUtils.isBlank()、Objects.isNull()三者区别
  • C语言-程序环境 #预处理 #编译 #汇编 #链接 #执行环境
  • Unity3D ARPG(动作角色扮演游戏)设计与实现详解
  • 第十五届蓝桥杯 Python 省赛题目及解析
  • 【限流器】golang令牌桶限流源码分析
  • 【Linux】常见指令及权限相关知识详细梳理
  • 找不同-第15届蓝桥省赛Scratch初级组真题第4题
  • ffmpeg视频转切片m3u8并加密videojs播放hls.js播放dplayer播放(弹幕效果)
  • Flutter中自定义气泡框效果的实现
  • SQL进阶技巧:如何利用SQL解决趣味赛马问题?| 非等值关联匹配问题
  • 第十九章 rust服务器开发:axum框架详解
  • Self-study Python Fish-C Note20 P64to65
  • 开源 AI 智能名片 O2O 商城小程序在营销中的应用
  • 在qt中,用户输入了16进制的字符串,如何按照用户的16进制格式发送
  • C语言第一周课
  • TypeScript(TS) 实现消息通知(发布订阅)
  • 视频监控系统布局策略:EasyCVR视频汇聚平台构建高效、全面的安全防线
  • 微服务配置管理
  • nodejs发邮件如何实现自动化邮件发送功能?
  • jenkins web界面构建job时平台展现的时间是6点,可是当前北京是14点,如何调整这个时间,如何调整 Jenkins 的时间显示
  • ant mobile design组件库的PickerView组件不能滑动
  • 思科IP访问控制列表3
  • SpringBoot配置返回数据不存在null
  • JUnit 5和Mockito进行单元测试!
  • Redis配置
  • 计算机毕业设计推荐-基于python的电子图书馆数据可视化分析
  • Tensorflow实现深度学习8:猫狗识别