吴忠躺衫网络科技有限公司

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

C語言實(shí)現(xiàn)AES算法

嵌入式應(yīng)用開發(fā) ? 來源: 嵌入式應(yīng)用開發(fā) ? 作者: 嵌入式應(yīng)用開發(fā) ? 2022-11-21 19:29 ? 次閱讀

AES加密算法流程圖如下圖所示:

pYYBAGN7X1KAAgBSAABxCYz0hKI495.png

明文P:未加密的原始數(shù)據(jù);密鑰K:加密原始數(shù)據(jù)密碼,對稱算法中,加密與解密所需的密鑰相同,該密鑰不能直接進(jìn)行傳輸,否則會(huì)造成密鑰泄露;常規(guī)的做法是使用非對稱算法對密鑰進(jìn)行加密之后再進(jìn)行傳輸。

AES加密函數(shù)加密函數(shù)將傳入的密鑰K與明文P進(jìn)行處理,之后生成一個(gè)被加密的信息密文C。

密文C:經(jīng)過密鑰加密后的數(shù)據(jù)。

AES解密函數(shù)解密函數(shù)將傳入的密鑰K與密文C進(jìn)行處理,之后生成一個(gè)沒有加密的明文P。

代碼部分講解:

AES算法相關(guān)接口在AES.h內(nèi),主要的接口:

uint8_t *aes_init(size_t key_size);
void aes_key_expansion(uint8_t *key, uint8_t *w);
void aes_inv_cipher(uint8_t *in, uint8_t *out, uint8_t *w);
void aes_cipher(uint8_t *in, uint8_t *out, uint8_t *w);

aes_init()函數(shù)作用:初始化aes變量,創(chuàng)建擴(kuò)展密鑰所需要的內(nèi)存
key_size:擴(kuò)展密鑰所需內(nèi)存大小

aes_key_expansion()作用:創(chuàng)建擴(kuò)展密鑰
key:擴(kuò)展密鑰
w:擴(kuò)展密鑰內(nèi)存首地址

aes_inv_cipher()作用:數(shù)據(jù)解密
in:輸入加密的信息
out:輸出解密后的信息
w:擴(kuò)展密鑰內(nèi)存首地址

aes_cipher()作用:數(shù)據(jù)加密
in:輸入未加密的信息
out:輸出加密后的信息
w:擴(kuò)展密鑰內(nèi)存首地址

代碼實(shí)現(xiàn)例程如下:

int main() {
    uint8_t i = 0;
    /* 256 bit key */
    uint8_t key[] = {
        0x00, 0x01, 0x02, 0x03,
        0x04, 0x05, 0x06, 0x07,
        0x08, 0x09, 0x0a, 0x0b,
        0x0c, 0x0d, 0x0e, 0x0f,
        0x10, 0x11, 0x12, 0x13,
        0x14, 0x15, 0x16, 0x17,
        0x18, 0x19, 0x1a, 0x1b,
        0x1c, 0x1d, 0x1e, 0x1f};
    uint8_t in[] = {
        0x00, 0x11, 0x22, 0x33,
        0x44, 0x55, 0x66, 0x77,
        0x88, 0x99, 0xaa, 0xbb,
        0xcc, 0xdd, 0xee, 0xff};
    uint8_t out[16];
    uint8_t *w = NULL;

    w = aes_init(sizeof(key));
    aes_key_expansion(key, w);
    printf("Plaintext message:n");
    for (i = 0; i < 4; i++) {
        printf("%02x %02x %02x %02x ", in[4*i+0], in[4*i+1], in[4*i+2], in[4*i+3]);
    }
    printf("n");
    aes_cipher(in, out, w);
    printf("Ciphered message:n");
    for (i = 0; i < 4; i++) {
        printf("%02x %02x %02x %02x ", out[4*i+0], out[4*i+1], out[4*i+2], out[4*i+3]);
    }
    printf("n");
    aes_inv_cipher(out, in, w);
    printf("Original message (after inv cipher):n");
    for (i = 0; i < 4; i++) {
        printf("%02x %02x %02x %02x ", in[4*i+0], in[4*i+1], in[4*i+2], in[4*i+3]);
    }
    printf("n");
    free(w);
    return 0;
}

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報(bào)投訴
  • 算法
    +關(guān)注

    關(guān)注

    23

    文章

    4630

    瀏覽量

    93348
  • C語言
    +關(guān)注

    關(guān)注

    180

    文章

    7614

    瀏覽量

    137702
  • 代碼
    +關(guān)注

    關(guān)注

    30

    文章

    4825

    瀏覽量

    69039
  • 加密算法
    +關(guān)注

    關(guān)注

    0

    文章

    216

    瀏覽量

    25580
  • AES算法
    +關(guān)注

    關(guān)注

    0

    文章

    13

    瀏覽量

    7860
收藏 人收藏

    評論

    相關(guān)推薦

    C語言實(shí)現(xiàn)數(shù)字信號(hào)處理算法

    C語言實(shí)現(xiàn)數(shù)字信號(hào)處理算法
    發(fā)表于 08-16 23:17

    CRC算法c語言實(shí)現(xiàn)

    CRC算法c語言實(shí)現(xiàn)
    發(fā)表于 08-20 19:21

    PID控制算法C語言實(shí)現(xiàn)(完整版)

    PID控制算法C語言實(shí)現(xiàn)(完整版)
    發(fā)表于 02-06 17:08

    PID控制算法C語言實(shí)現(xiàn)(完整版)

    PID控制算法C語言實(shí)現(xiàn)(完整版)
    發(fā)表于 04-02 11:39

    PID控制算法C語言實(shí)現(xiàn)(完整版)

    PID控制算法C語言實(shí)現(xiàn)(完整版)
    發(fā)表于 05-01 11:03

    請問如何使用Verilog硬件描述語言實(shí)現(xiàn)AES密碼算法

    如何使用Verilog硬件描述語言實(shí)現(xiàn)AES密碼算法
    發(fā)表于 04-14 06:29

    C語言實(shí)現(xiàn)常用排序算法是什么?

    C語言實(shí)現(xiàn)常用排序算法是什么?
    發(fā)表于 10-19 06:41

    CRC算法原理及C語言實(shí)現(xiàn)

    CRC算法原理及C語言實(shí)現(xiàn):本文從理論上推導(dǎo)出CRC 算法實(shí)現(xiàn)原理,給出三種分別適應(yīng)不同計(jì)算機(jī)或微控制器硬件環(huán)境的
    發(fā)表于 09-23 23:38 ?31次下載

    C語言實(shí)現(xiàn)DES算法

    C語言實(shí)現(xiàn)DES算法 本DES算法,使用了效率很高的C完成。目前,國內(nèi)知名企業(yè)的POS終端中,單DES
    發(fā)表于 01-16 10:09 ?3277次閱讀

    C語言實(shí)現(xiàn)FFT算法

    C語言實(shí)現(xiàn)FFT算法 /*****************fft programe*********************/#include "typedef.h" #include "math.h" struct
    發(fā)表于 10-30 13:39 ?6359次閱讀

    DSP算法c語言實(shí)現(xiàn)

    DSP算法c語言實(shí)現(xiàn),又需要的朋友下來看看。
    發(fā)表于 05-09 10:59 ?0次下載

    卡爾曼濾波算法C語言實(shí)現(xiàn)

    卡爾曼濾波算法C語言實(shí)現(xiàn) 可以運(yùn)行STM32 和 arduino上 已測試成功
    發(fā)表于 09-27 16:34 ?68次下載

    PID控制算法C語言實(shí)現(xiàn)(完整版)

    PID控制算法C語言實(shí)現(xiàn)一 PID算法原理
    發(fā)表于 11-05 15:45 ?0次下載

    4個(gè)重要算法C語言實(shí)現(xiàn)源代碼

    4個(gè)重要算法C語言實(shí)現(xiàn)源代碼
    發(fā)表于 06-10 08:00 ?12次下載

    CRC校驗(yàn)算法原理及c語言實(shí)現(xiàn)

    CRC校驗(yàn)算法原理及c語言實(shí)現(xiàn)
    發(fā)表于 11-30 10:04 ?9次下載
    百家乐澳门百家乐| 澳门百家乐官网娱乐城打不开| 足球皇冠大全| 新时代百家乐娱乐城| 百家乐怎么玩才会赢钱| 澳门百家乐的玩法技巧和规则| 免费百家乐分析工具| 大发888娱乐场大发888娱乐场下载| 亿酷棋牌室| 东方夏威夷网站| 锡林浩特市| 百家乐官网的视频百家乐官网| 百家乐官网楼梯缆大全| rmb百家乐官网的玩法技巧和规则| 属鼠做生意办公桌摆貔貅好不好 | 百家乐官网遥控洗牌器| 二爷百家乐官网的玩法技巧和规则| 百家乐官网平注法规则| 属兔魔羯女在哪个方位做生意| 线上百家乐赌法| 博e百娱乐城怎么样| 合法赌博网站| 百家乐官网最佳下注方法| 百家乐官网娱乐网会员注册| 棋牌百家乐怎么玩| 百家乐官网15人桌布| 真人百家乐技巧| 百家乐二代理解| 谁会玩百家乐的玩法技巧和规则| 大发888真钱娱乐网| 鸡东县| 百家乐官网游戏唯一官网网站| 澳门百家乐娱乐城打不开| 水浒传老虎机破解| 乌拉特中旗| 贵族百家乐官网的玩法技巧和规则 | 百家乐遥控洗牌器| bet365打不开| 太阳城百家乐官网出千技术 | 太阳城百家乐分析解码| 大发888官方下载网址|