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

举报
软件算法开发 发表于 2025/06/03 00:02:23 2025/06/03
【摘要】 1.程序功能描述        基于AES的图像加解密算法matlab仿真,带GUI界面。在GUI界面上进行操作,分别对图像进行AES加密,AES解密。2.测试软件版本以及运行结果展示MATLAB2022A版本运行(完整程序运行后无水印)3.核心程序% --- Executes on button press in pushbutton3.function pushbutton3_Callb...

1.程序功能描述
        基于AES的图像加解密算法matlab仿真,带GUI界面。在GUI界面上进行操作,分别对图像进行AES加密,AES解密。

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

1.jpeg

2.jpeg

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

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;

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

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

初始轮(Initial Round)

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

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

这一轮不包括列混淆步骤,其余步骤与主循环相同。
4.2 解密过程
解密过程是加密过程的逆向操作。具体步骤如下:

初始轮(Initial Round)

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

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

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

【版权声明】本文为华为云社区用户原创内容,未经允许不得转载,如需转载请自行联系原作者进行授权。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。