找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
查看: 11467|回复: 22
收起左侧

STM32 16字节加解密的AES算法程序源码

  [复制链接]
ID:82014 发表于 2018-4-26 15:19 | 显示全部楼层 |阅读模式
stm32 AES动态加密算法,大家可以下载进行测试

1、该算法工程是基于Keil5环境进行编译下载,单片机型号是stm32f030c8.

2、打开文件夹Project,双击"16BytesAES.uvprojx",即可打开工程。

3、如果不想利用该工程,只需要拷贝文件夹USER下的AES.c,AES.h,main.c到自己的工程,修改头文件即可。

stm32单片机源程序如下:
  1. /**
  2.   ******************************************************************************
  3.   * @file    GPIO/GPIO_IOToggle/main.c
  4.   * @author  MCD Application Team
  5.   * @version V1.4.0
  6.   * @brief   Main program body
  7.   ******************************************************************************
  8.   * @attention
  9.   *
  10.   * <h2><center>© COPYRIGHT 2014 STMicroelectronics</center></h2>
  11.   *
  12.   * Licensed under MCD-ST Liberty SW License Agreement V2, (the "License");
  13.   * You may not use this file except in compliance with the License.
  14.   * You may obtain a copy of the License at:
  15.   *
  16.   *        http://www.st.com/software_license_agreement_liberty_v2
  17.   *
  18.   * Unless required by applicable law or agreed to in writing, software
  19.   * distributed under the License is distributed on an "AS IS" BASIS,
  20.   * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  21.   * See the License for the specific language governing permissions and
  22.   * limitations under the License.
  23.   *
  24.   ******************************************************************************
  25.   */

  26. /* Includes ------------------------------------------------------------------*/
  27. #include "stm32f0xx.h"
  28. #include "stm32f0xx_conf.h"
  29. #include "stdio.h"
  30. #include "stdlib.h"
  31. #include "Mcu_config.h"
  32. #include "Serial.h"
  33. #include "AES.h"

  34. /** @addtogroup STM32F0xx_StdPeriph_Examples
  35.   * @{
  36.   */

  37. /** @addtogroup GPIO_IOToggle
  38.   * @{
  39.   */

  40. /* Private typedef -----------------------------------------------------------*/
  41. /* Private define ------------------------------------------------------------*/

  42. #ifdef __GNUC__
  43.   /* With GCC/RAISONANCE, small printf (option LD Linker->Libraries->Small printf
  44.      set to 'Yes') calls __io_putchar() */
  45.   #define PUTCHAR_PROTOTYPE int __io_putchar(int ch)
  46. #else
  47.   #define PUTCHAR_PROTOTYPE int fputc(int ch, FILE *f)
  48. #endif /* __GNUC__ */
  49.        
  50.        
  51.        

  52. /* Private macro -------------------------------------------------------------*/
  53. /* Private variables ---------------------------------------------------------*/


  54. /* Private function prototypes -----------------------------------------------*/
  55. /* Private functions ---------------------------------------------------------*/

  56. /**
  57.   * @brief  Main program.
  58.   * @param  None
  59.   * @retval None
  60.   */


  61. char expressText[1024];  //存放待加密的明文数据,具体缓存大小根据用户待加密数据长度自己任意修改
  62. char cipherText[1024];//存放已加密的密文数据,具体缓存大小根据用户解密后的数据长度自己任意修改
  63. char aesKey[16];//加解密的密钥,注意:此算法只适用于AES16位密钥加解密,不适用于32位密钥加解密

  64. //该AES算法加密方式为:AES-128bit/ECB/PKCS5Padding

  65. /*
  66. 欢迎加入
  67. 二手开发板供求交易群  68936520
  68. arm交流学习群    324753668
  69. stm32交流学习群  227043677
  70. */
  71. int main(void)
  72. {
  73.         MCU_Init();
  74.        
  75.         delay_1ms(2000);
  76.        
  77.         memcpy(aesKey , "1uweiIDAS7awOas8" , 16);  //AES加密密钥,16字节(128bit)
  78.        
  79.         memset(expressText ,0 ,1024);
  80.         memset(cipherText , 0 ,1024);
  81.         strcpy(expressText , "Hello!!!Are you ready???");
  82.         AES_Encrypt(expressText  , cipherText , aesKey);        //use aesKey encrypt
  83.        
  84.         memset(expressText ,0 ,1024);
  85.         AES_Decrypt(expressText , cipherText , aesKey);//use aesKey decrypt               

  86.   while(1)
  87.   {

  88.                 delay_1ms(2000);
  89.   }
  90.        
  91. }

  92. /**
  93.   * @brief  Retargets the C library printf function to the USART.
  94.   * @param  None
  95.   * @retval None
  96.   */
  97. PUTCHAR_PROTOTYPE
  98. {
  99.   /* Place your implementation of fputc here */
  100.   /* e.g. write a character to the USART */
  101.        
  102.   USART_SendData(USART2, (uint8_t) ch);

  103.   /* Loop until transmit data register is empty */
  104.   while (USART_GetFlagStatus(USART2, USART_FLAG_TXE) == RESET)
  105.   {}

  106.   return ch;
  107. }
  108. #ifdef  USE_FULL_ASSERT

  109. /**
  110.   * @brief  Reports the name of the source file and the source line number
  111.   *         where the assert_param error has occurred.
  112.   * @param  file: pointer to the source file name
  113.   * @param  line: assert_param error line source number
  114.   * @retval None
  115.   */
  116. void assert_failed(uint8_t* file, uint32_t line)
  117. {
  118.   /* User can add his own implementation to report the file name and line number,
  119.      ex: printf("Wrong parameters value: file %s on line %d\r\n", file, line) */

  120.   /* Infinite loop */
  121.   while (1)
  122.   {
  123.   }
  124. }
  125. #endif

  126. void fault_handler_c(unsigned int * hardfault_args, unsigned int type);
  127. ……………………

  128. …………限于本文篇幅 余下代码请从51黑下载附件…………
复制代码

所有资料51hei提供下载:

16字节加解密的AES算法.zip (1.59 MB, 下载次数: 398)
回复

使用道具 举报

ID:318517 发表于 2018-4-28 16:20 | 显示全部楼层
好资料,学习下
回复

使用道具 举报

ID:318517 发表于 2018-5-2 15:20 | 显示全部楼层
学习
回复

使用道具 举报

ID:355846 发表于 2018-6-21 11:00 | 显示全部楼层
很好,下来学习一下。
回复

使用道具 举报

ID:164590 发表于 2018-8-28 09:49 | 显示全部楼层
好好学习一下!
回复

使用道具 举报

ID:349170 发表于 2018-8-31 15:38 | 显示全部楼层
加密模式是什么?ECB,CBC,CTR?
回复

使用道具 举报

ID:90358 发表于 2018-9-3 14:44 | 显示全部楼层
测试没通过
回复

使用道具 举报

ID:106325 发表于 2019-1-23 14:52 | 显示全部楼层
好资料不错
回复

使用道具 举报

ID:289330 发表于 2019-1-23 16:13 | 显示全部楼层
好资料,不错
回复

使用道具 举报

ID:152003 发表于 2019-1-24 10:16 | 显示全部楼层
好资料 试一下
回复

使用道具 举报

ID:393586 发表于 2019-3-7 10:56 | 显示全部楼层
代码有问题,测试结果错误
回复

使用道具 举报

ID:553992 发表于 2019-6-4 11:51 | 显示全部楼层




//去除末尾补码
        buIndex = str2[aesDataLen-1];
        for(i=0; i<buIndex; i++)
        {
                if(str2[aesDataLen-i-1] != buIndex)
                {
                        //UART_Printf("\nit is a wrong data. \n");
                       
            //free(str2);   //pming,2019.06.04
                        //return;
            break;
                }
                else
                        str2[aesDataLen-i-1] = '\0';
        
        }
        strcpy(pExpressText , str2);
        free(str2);

解密返回为空。我将 加日期批注的地方2行,修改之后,可以解密。但长度似乎不对。
回复

使用道具 举报

ID:256220 发表于 2019-7-4 19:34 | 显示全部楼层
楼主的东西我测试了的,ok,没问题,谢谢
回复

使用道具 举报

ID:475809 发表于 2019-8-26 09:46 | 显示全部楼层
下载几次都失败了
回复

使用道具 举报

ID:195932 发表于 2019-8-29 04:39 | 显示全部楼层
好资料,学习下
回复

使用道具 举报

ID:245560 发表于 2019-9-5 16:02 | 显示全部楼层
遇到了12楼一样的问题,解密后返回为空
回复

使用道具 举报

ID:491881 发表于 2019-9-20 15:11 | 显示全部楼层
好资料,学习下
回复

使用道具 举报

ID:642434 发表于 2019-11-15 09:45 | 显示全部楼层
看起来资料不错, 没分下载, 楼主能不能分少点
回复

使用道具 举报

ID:407413 发表于 2019-12-6 17:20 | 显示全部楼层
解密数据为空的啊
回复

使用道具 举报

ID:147591 发表于 2019-12-9 10:20 | 显示全部楼层
试试看能不能用
回复

使用道具 举报

ID:635961 发表于 2020-2-24 11:20 | 显示全部楼层
谢谢分享,刚好想参考一下,学习AES加密
回复

使用道具 举报

ID:594820 发表于 2020-4-2 22:18 | 显示全部楼层
正好用到,谢谢分享!
回复

使用道具 举报

ID:800529 发表于 2023-12-14 10:12 | 显示全部楼层
我现在也需要,下载学习。
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

手机版|小黑屋|51黑电子论坛 |51黑电子论坛6群 QQ 管理员QQ:125739409;技术交流QQ群281945664

Powered by 单片机教程网

快速回复 返回顶部 返回列表