日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 人文社科 > 生活经验 >内容正文

生活经验

C语言实现AES加解密

發布時間:2023/11/27 生活经验 45 豆豆
生活随笔 收集整理的這篇文章主要介紹了 C语言实现AES加解密 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

C語言實現AES加解密

  • AES算法
  • 具體代碼

AES算法

(AES)RIJNDAEL算法是一個數據塊長度盒密鑰長度都可變的分組加密算法,其數據塊長度和密鑰長度都可獨立地選定為大于等于128位且小于等于256位的32位任意倍數。在本次實驗中采用的是128位數據和密鑰長度。
RIJNDAEL算法結構如圖:

輪函數
RIJNDAEL的輪函數由以下三層組成:
①非線性層:進行非線性S盒變換subByte,由16個S盒并置而成,起混淆的作用。
②線性混合層:進行行移位變換shiftRow和列混合變換mixColumn以確保多輪之上的高度擴散。
③密鑰加層:進行輪密鑰加變換addRoundKey,將輪密鑰簡單地異或到中間狀態上,實現密鑰地加密控制作用。
輪函數用偽c語言表述為(state為明文加密狀態):

Round(state,RoundKey){subByte(state);shiftRow(state);mixColumn(state);addRoundKey(state, RoundKey);}
**加密算法中最后一輪的輪函數域上面的標準函數略有不同(沒有mixColumn(state))**

(1)其中,S盒變換subByte是按照字節進行的代替變換。
假設i是state中某字節,則經過替換后:i=SBOX[i];

S盒如下:int SBOX[256] =   {0x63, 0x7c, 0x77, 0x7b, 0xf2, 0x6b, 0x6f, 0xc5, 0x30, 0x01, 0x67, 0x2b, 0xfe, 0xd7, 0xab, 0x76,0xca, 0x82, 0xc9, 0x7d, 0xfa, 0x59, 0x47, 0xf0, 0xad, 0xd4, 0xa2, 0xaf, 0x9c, 0xa4, 0x72, 0xc0,0xb7, 0xfd, 0x93, 0x26, 0x36, 0x3f, 0xf7, 0xcc, 0x34, 0xa5, 0xe5, 0xf1, 0x71, 0xd8, 0x31, 0x15,0x04, 0xc7, 0x23, 0xc3, 0x18, 0x96, 0x05, 0x9a, 0x07, 0x12, 0x80, 0xe2, 0xeb, 0x27, 0xb2, 0x75,0x09, 0x83, 0x2c, 0x1a, 0x1b, 0x6e, 0x5a, 0xa0, 0x52, 0x3b, 0xd6, 0xb3, 0x29, 0xe3, 0x2f, 0x84,0x53, 0xd1, 0x00, 0xed, 0x20, 0xfc, 0xb1, 0x5b, 0x6a, 0xcb, 0xbe, 0x39, 0x4a, 0x4c, 0x58, 0xcf,0xd0, 0xef, 0xaa, 0xfb, 0x43, 0x4d, 0x33, 0x85, 0x45, 0xf9, 0x02, 0x7f, 0x50, 0x3c, 0x9f, 0xa8,0x51, 0xa3, 0x40, 0x8f, 0x92, 0x9d, 0x38, 0xf5, 0xbc, 0xb6, 0xda, 0x21, 0x10, 0xff, 0xf3, 0xd2,0xcd, 0x0c, 0x13, 0xec, 0x5f, 0x97, 0x44, 0x17, 0xc4, 0xa7, 0x7e, 0x3d, 0x64, 0x5d, 0x19, 0x73,0x60, 0x81, 0x4f, 0xdc, 0x22, 0x2a, 0x90, 0x88, 0x46, 0xee, 0xb8, 0x14, 0xde, 0x5e, 0x0b, 0xdb,0xe0, 0x32, 0x3a, 0x0a, 0x49, 0x06, 0x24, 0x5c, 0xc2, 0xd3, 0xac, 0x62, 0x91, 0x95, 0xe4, 0x79,0xe7, 0xc8, 0x37, 0x6d, 0x8d, 0xd5, 0x4e, 0xa9, 0x6c, 0x56, 0xf4, 0xea, 0x65, 0x7a, 0xae, 0x08,0xba, 0x78, 0x25, 0x2e, 0x1c, 0xa6, 0xb4, 0xc6, 0xe8, 0xdd, 0x74, 0x1f, 0x4b, 0xbd, 0x8b, 0x8a,0x70, 0x3e, 0xb5, 0x66, 0x48, 0x03, 0xf6, 0x0e, 0x61, 0x35, 0x57, 0xb9, 0x86, 0xc1, 0x1d, 0x9e,0xe1, 0xf8, 0x98, 0x11, 0x69, 0xd9, 0x8e, 0x94, 0x9b, 0x1e, 0x87, 0xe9, 0xce, 0x55, 0x28, 0xdf,0x8c, 0xa1, 0x89, 0x0d, 0xbf, 0xe6, 0x42, 0x68, 0x41, 0x99, 0x2d, 0x0f, 0xb0, 0x54, 0xbb, 0x16 
};

(2)行移位和Nb的關系(數字代表上移次數):
本實驗中Nb=4;

一次行移位變換示例(此實驗為了方便結果閱讀,行和列與一般定義不同),從左到右:
state[4][4]={									state[4][4]={1,    2,    3,     4,							1,   6,   11,   16,   //第一行5,    6,    7,     8, 							5,   10,  15,    4,  //第二行                     9,   10,   11,    12,						 	9,   14,   3,    8,  //第三行13,   14,   15,    16						   13,   2,   7,    12  …… 	
}											}

(3)列混淆變換mixColumn是對狀態列的混淆變換。在mixColumn中,把狀態中每一列看作伽羅華域GF(2^8) 上的多項式與一固定多項式相乘然后模多項式 x^4-1。該多項式為:

(4)輪密鑰加變換addRoundKey是利用輪密鑰對狀態進行模2相加的變換。

密鑰擴展
用一個四字節元素的一維數組(一個元素為一行)RoundKey[Nb*(Nr+1)]表示擴展密鑰。
本實驗中的密鑰擴展策略(偽c代碼表示):

	keyExpansion(key,RoundKey){for(i=0;i<Nk;i++)Roundkey[i]=key[i]//第一輪密鑰即原密鑰while(i<(Nb*(Nr+1))){temp=RoundKey[i];if(i%4==0){rotWord(temp);subWord(temp);temp[0]^=Rocn[i/Nk];}RoundKey[i]=RoundKey[i-Nk]^temp;i++;}}

Rcon表如下,實際上只需要Rocn[1-10]:

int Rcon[255] = {0x8d, 0x01, 0x02, 0x04, 0x08, 0x10, 0x20, 0x40, 0x80, 0x1b, 0x36, 0x6c, 0xd8, 0xab, 0x4d, 0x9a,0x2f, 0x5e, 0xbc, 0x63, 0xc6, 0x97, 0x35, 0x6a, 0xd4, 0xb3, 0x7d, 0xfa, 0xef, 0xc5, 0x91, 0x39,0x72, 0xe4, 0xd3, 0xbd, 0x61, 0xc2, 0x9f, 0x25, 0x4a, 0x94, 0x33, 0x66, 0xcc, 0x83, 0x1d, 0x3a,0x74, 0xe8, 0xcb, 0x8d, 0x01, 0x02, 0x04, 0x08, 0x10, 0x20, 0x40, 0x80, 0x1b, 0x36, 0x6c, 0xd8,0xab, 0x4d, 0x9a, 0x2f, 0x5e, 0xbc, 0x63, 0xc6, 0x97, 0x35, 0x6a, 0xd4, 0xb3, 0x7d, 0xfa, 0xef,0xc5, 0x91, 0x39, 0x72, 0xe4, 0xd3, 0xbd, 0x61, 0xc2, 0x9f, 0x25, 0x4a, 0x94, 0x33, 0x66, 0xcc,0x83, 0x1d, 0x3a, 0x74, 0xe8, 0xcb, 0x8d, 0x01, 0x02, 0x04, 0x08, 0x10, 0x20, 0x40, 0x80, 0x1b,0x36, 0x6c, 0xd8, 0xab, 0x4d, 0x9a, 0x2f, 0x5e, 0xbc, 0x63, 0xc6, 0x97, 0x35, 0x6a, 0xd4, 0xb3,0x7d, 0xfa, 0xef, 0xc5, 0x91, 0x39, 0x72, 0xe4, 0xd3, 0xbd, 0x61, 0xc2, 0x9f, 0x25, 0x4a, 0x94,0x33, 0x66, 0xcc, 0x83, 0x1d, 0x3a, 0x74, 0xe8, 0xcb, 0x8d, 0x01, 0x02, 0x04, 0x08, 0x10, 0x20,0x40, 0x80, 0x1b, 0x36, 0x6c, 0xd8, 0xab, 0x4d, 0x9a, 0x2f, 0x5e, 0xbc, 0x63, 0xc6, 0x97, 0x35,0x6a, 0xd4, 0xb3, 0x7d, 0xfa, 0xef, 0xc5, 0x91, 0x39, 0x72, 0xe4, 0xd3, 0xbd, 0x61, 0xc2, 0x9f,0x25, 0x4a, 0x94, 0x33, 0x66, 0xcc, 0x83, 0x1d, 0x3a, 0x74, 0xe8, 0xcb, 0x8d, 0x01, 0x02, 0x04,0x08, 0x10, 0x20, 0x40, 0x80, 0x1b, 0x36, 0x6c, 0xd8, 0xab, 0x4d, 0x9a, 0x2f, 0x5e, 0xbc, 0x63,0xc6, 0x97, 0x35, 0x6a, 0xd4, 0xb3, 0x7d, 0xfa, 0xef, 0xc5, 0x91, 0x39, 0x72, 0xe4, 0xd3, 0xbd,0x61, 0xc2, 0x9f, 0x25, 0x4a, 0x94, 0x33, 0x66, 0xcc, 0x83, 0x1d, 0x3a, 0x74, 0xe8, 0xcb
};

逆變換
(1)subByte的逆是RIJNDAEL的R_SBOX作用到狀態的每個字節上,R_SBOX如下:

int R_SBOX[256] ={ 0x52, 0x09, 0x6a, 0xd5, 0x30, 0x36, 0xa5, 0x38, 0xbf, 0x40, 0xa3, 0x9e, 0x81, 0xf3, 0xd7, 0xfb, 0x7c, 0xe3, 0x39, 0x82, 0x9b, 0x2f, 0xff, 0x87, 0x34, 0x8e, 0x43, 0x44, 0xc4, 0xde, 0xe9, 0xcb, 0x54, 0x7b, 0x94, 0x32, 0xa6, 0xc2, 0x23, 0x3d, 0xee, 0x4c, 0x95, 0x0b, 0x42, 0xfa, 0xc3, 0x4e, 0x08, 0x2e,0xa1, 0x66, 0x28, 0xd9, 0x24, 0xb2, 0x76, 0x5b, 0xa2, 0x49, 0x6d, 0x8b, 0xd1, 0x25, 0x72, 0xf8, 0xf6, 0x64, 0x86, 0x68, 0x98, 0x16, 0xd4, 0xa4, 0x5c, 0xcc, 0x5d, 0x65, 0xb6, 0x92, 0x6c, 0x70, 0x48, 0x50, 0xfd, 0xed, 0xb9, 0xda, 0x5e, 0x15, 0x46, 0x57, 0xa7, 0x8d, 0x9d, 0x84, 0x90, 0xd8, 0xab, 0x00, 0x8c, 0xbc, 0xd3, 0x0a, 0xf7, 0xe4, 0x58, 0x05, 0xb8, 0xb3, 0x45, 0x06, 0xd0, 0x2c, 0x1e, 0x8f, 0xca, 0x3f, 0x0f, 0x02, 0xc1, 0xaf, 0xbd, 0x03, 0x01, 0x13, 0x8a, 0x6b, 0x3a, 0x91, 0x11, 0x41, 0x4f, 0x67, 0xdc, 0xea, 0x97, 0xf2, 0xcf, 0xce, 0xf0, 0xb4, 0xe6, 0x73, 0x96, 0xac, 0x74, 0x22, 0xe7, 0xad, 0x35, 0x85, 0xe2, 0xf9, 0x37, 0xe8, 0x1c, 0x75, 0xdf, 0x6e, 0x47, 0xf1, 0x1a, 0x71, 0x1d, 0x29, 0xc5, 0x89, 0x6f, 0xb7, 0x62, 0x0e, 0xaa, 0x18, 0xbe, 0x1b, 0xfc, 0x56, 0x3e, 0x4b, 0xc6, 0xd2, 0x79, 0x20, 0x9a, 0xdb, 0xc0, 0xfe, 0x78, 0xcd, 0x5a, 0xf4, 0x1f, 0xdd, 0xa8, 0x33, 0x88, 0x07, 0xc7, 0x31, 0xb1, 0x12, 0x10, 0x59, 0x27, 0x80, 0xec, 0x5f, 0x60, 0x51, 0x7f, 0xa9, 0x19, 0xb5, 0x4a, 0x0d, 0x2d, 0xe5, 0x7a, 0x9f, 0x93, 0xc9, 0x9c, 0xef, 0xa0, 0xe0, 0x3b, 0x4d, 0xae, 0x2a, 0xf5, 0xb0, 0xc8, 0xeb, 0xbb, 0x3c, 0x83, 0x53, 0x99, 0x61, 0x17, 0x2b, 0x04, 0x7e, 0xba, 0x77, 0xd6, 0x26, 0xe1, 0x69, 0x14, 0x63, 0x55, 0x21, 0x0c, 0x7d
};

(2)shiftRow的逆是后三行分別下移1,2,3行。
(3)mixColumn的逆類似于mixColumn,狀態的每列都乘以一個固定多項式:
(4)addRoundKey的逆即它本身。

RIJNDAEL加密過程

			keyExpansion();	addRoundKey(0);     //addRoundKey中的數字表示輪密鑰的編號(0-10)for(round=1;round<Nr;round++){subBytes();shiftRows();mixColumns();addRoundKey(round);}subBytes();      //此處即FinalRound()shiftRows();addRoundKey(Nr);

RIJNDAEL解密過程

			keyExpansion();addRoundKey(Nr);for(round=Nr-1;round>0;round--){invSubBytes();invShiftRows();addRoundKey(round);invMixColumns();}invSubBytes();	invShiftRows();addRoundKey(0);

具體代碼

#include<stdio.h>
#include<string.h> 
#include<time.h>
#include<windows.h> #define Nb 4   //數據塊行數 
#define Nk 4   //密碼塊行數 
#define Nr 10  //輪加密次數 unsigned char RoundKey[4*Nb*(Nr+1)]; //輪密鑰 
unsigned char Key[17];     //密鑰 
unsigned char state[4][4];  //明文加密狀態 //實際上只需要用Rocn[1-10] 
int Rcon[255] = {0x8d, 0x01, 0x02, 0x04, 0x08, 0x10, 0x20, 0x40, 0x80, 0x1b, 0x36, 0x6c, 0xd8, 0xab, 0x4d, 0x9a,0x2f, 0x5e, 0xbc, 0x63, 0xc6, 0x97, 0x35, 0x6a, 0xd4, 0xb3, 0x7d, 0xfa, 0xef, 0xc5, 0x91, 0x39,0x72, 0xe4, 0xd3, 0xbd, 0x61, 0xc2, 0x9f, 0x25, 0x4a, 0x94, 0x33, 0x66, 0xcc, 0x83, 0x1d, 0x3a,0x74, 0xe8, 0xcb, 0x8d, 0x01, 0x02, 0x04, 0x08, 0x10, 0x20, 0x40, 0x80, 0x1b, 0x36, 0x6c, 0xd8,0xab, 0x4d, 0x9a, 0x2f, 0x5e, 0xbc, 0x63, 0xc6, 0x97, 0x35, 0x6a, 0xd4, 0xb3, 0x7d, 0xfa, 0xef,0xc5, 0x91, 0x39, 0x72, 0xe4, 0xd3, 0xbd, 0x61, 0xc2, 0x9f, 0x25, 0x4a, 0x94, 0x33, 0x66, 0xcc,0x83, 0x1d, 0x3a, 0x74, 0xe8, 0xcb, 0x8d, 0x01, 0x02, 0x04, 0x08, 0x10, 0x20, 0x40, 0x80, 0x1b,0x36, 0x6c, 0xd8, 0xab, 0x4d, 0x9a, 0x2f, 0x5e, 0xbc, 0x63, 0xc6, 0x97, 0x35, 0x6a, 0xd4, 0xb3,0x7d, 0xfa, 0xef, 0xc5, 0x91, 0x39, 0x72, 0xe4, 0xd3, 0xbd, 0x61, 0xc2, 0x9f, 0x25, 0x4a, 0x94,0x33, 0x66, 0xcc, 0x83, 0x1d, 0x3a, 0x74, 0xe8, 0xcb, 0x8d, 0x01, 0x02, 0x04, 0x08, 0x10, 0x20,0x40, 0x80, 0x1b, 0x36, 0x6c, 0xd8, 0xab, 0x4d, 0x9a, 0x2f, 0x5e, 0xbc, 0x63, 0xc6, 0x97, 0x35,0x6a, 0xd4, 0xb3, 0x7d, 0xfa, 0xef, 0xc5, 0x91, 0x39, 0x72, 0xe4, 0xd3, 0xbd, 0x61, 0xc2, 0x9f,0x25, 0x4a, 0x94, 0x33, 0x66, 0xcc, 0x83, 0x1d, 0x3a, 0x74, 0xe8, 0xcb, 0x8d, 0x01, 0x02, 0x04,0x08, 0x10, 0x20, 0x40, 0x80, 0x1b, 0x36, 0x6c, 0xd8, 0xab, 0x4d, 0x9a, 0x2f, 0x5e, 0xbc, 0x63,0xc6, 0x97, 0x35, 0x6a, 0xd4, 0xb3, 0x7d, 0xfa, 0xef, 0xc5, 0x91, 0x39, 0x72, 0xe4, 0xd3, 0xbd,0x61, 0xc2, 0x9f, 0x25, 0x4a, 0x94, 0x33, 0x66, 0xcc, 0x83, 0x1d, 0x3a, 0x74, 0xe8, 0xcb
};//s盒 
int SBOX[256] =   {//0     1    2      3     4    5     6     7      8    9     A      B    C     D     E     F0x63, 0x7c, 0x77, 0x7b, 0xf2, 0x6b, 0x6f, 0xc5, 0x30, 0x01, 0x67, 0x2b, 0xfe, 0xd7, 0xab, 0x76,0xca, 0x82, 0xc9, 0x7d, 0xfa, 0x59, 0x47, 0xf0, 0xad, 0xd4, 0xa2, 0xaf, 0x9c, 0xa4, 0x72, 0xc0,0xb7, 0xfd, 0x93, 0x26, 0x36, 0x3f, 0xf7, 0xcc, 0x34, 0xa5, 0xe5, 0xf1, 0x71, 0xd8, 0x31, 0x15,0x04, 0xc7, 0x23, 0xc3, 0x18, 0x96, 0x05, 0x9a, 0x07, 0x12, 0x80, 0xe2, 0xeb, 0x27, 0xb2, 0x75,0x09, 0x83, 0x2c, 0x1a, 0x1b, 0x6e, 0x5a, 0xa0, 0x52, 0x3b, 0xd6, 0xb3, 0x29, 0xe3, 0x2f, 0x84,0x53, 0xd1, 0x00, 0xed, 0x20, 0xfc, 0xb1, 0x5b, 0x6a, 0xcb, 0xbe, 0x39, 0x4a, 0x4c, 0x58, 0xcf,0xd0, 0xef, 0xaa, 0xfb, 0x43, 0x4d, 0x33, 0x85, 0x45, 0xf9, 0x02, 0x7f, 0x50, 0x3c, 0x9f, 0xa8,0x51, 0xa3, 0x40, 0x8f, 0x92, 0x9d, 0x38, 0xf5, 0xbc, 0xb6, 0xda, 0x21, 0x10, 0xff, 0xf3, 0xd2,0xcd, 0x0c, 0x13, 0xec, 0x5f, 0x97, 0x44, 0x17, 0xc4, 0xa7, 0x7e, 0x3d, 0x64, 0x5d, 0x19, 0x73,0x60, 0x81, 0x4f, 0xdc, 0x22, 0x2a, 0x90, 0x88, 0x46, 0xee, 0xb8, 0x14, 0xde, 0x5e, 0x0b, 0xdb,0xe0, 0x32, 0x3a, 0x0a, 0x49, 0x06, 0x24, 0x5c, 0xc2, 0xd3, 0xac, 0x62, 0x91, 0x95, 0xe4, 0x79,0xe7, 0xc8, 0x37, 0x6d, 0x8d, 0xd5, 0x4e, 0xa9, 0x6c, 0x56, 0xf4, 0xea, 0x65, 0x7a, 0xae, 0x08,0xba, 0x78, 0x25, 0x2e, 0x1c, 0xa6, 0xb4, 0xc6, 0xe8, 0xdd, 0x74, 0x1f, 0x4b, 0xbd, 0x8b, 0x8a,0x70, 0x3e, 0xb5, 0x66, 0x48, 0x03, 0xf6, 0x0e, 0x61, 0x35, 0x57, 0xb9, 0x86, 0xc1, 0x1d, 0x9e,0xe1, 0xf8, 0x98, 0x11, 0x69, 0xd9, 0x8e, 0x94, 0x9b, 0x1e, 0x87, 0xe9, 0xce, 0x55, 0x28, 0xdf,0x8c, 0xa1, 0x89, 0x0d, 0xbf, 0xe6, 0x42, 0x68, 0x41, 0x99, 0x2d, 0x0f, 0xb0, 0x54, 0xbb, 0x16 
};//逆s盒 
int R_SBOX[256] ={ 0x52, 0x09, 0x6a, 0xd5, 0x30, 0x36, 0xa5, 0x38, 0xbf, 0x40, 0xa3, 0x9e, 0x81, 0xf3, 0xd7, 0xfb, 0x7c, 0xe3, 0x39, 0x82, 0x9b, 0x2f, 0xff, 0x87, 0x34, 0x8e, 0x43, 0x44, 0xc4, 0xde, 0xe9, 0xcb, 0x54, 0x7b, 0x94, 0x32, 0xa6, 0xc2, 0x23, 0x3d, 0xee, 0x4c, 0x95, 0x0b, 0x42, 0xfa, 0xc3, 0x4e, 0x08, 0x2e, 0xa1, 0x66, 0x28, 0xd9, 0x24, 0xb2, 0x76, 0x5b, 0xa2, 0x49, 0x6d, 0x8b, 0xd1, 0x25, 0x72, 0xf8, 0xf6, 0x64, 0x86, 0x68, 0x98, 0x16, 0xd4, 0xa4, 0x5c, 0xcc, 0x5d, 0x65, 0xb6, 0x92, 0x6c, 0x70, 0x48, 0x50, 0xfd, 0xed, 0xb9, 0xda, 0x5e, 0x15, 0x46, 0x57, 0xa7, 0x8d, 0x9d, 0x84, 0x90, 0xd8, 0xab, 0x00, 0x8c, 0xbc, 0xd3, 0x0a, 0xf7, 0xe4, 0x58, 0x05, 0xb8, 0xb3, 0x45, 0x06, 0xd0, 0x2c, 0x1e, 0x8f, 0xca, 0x3f, 0x0f, 0x02, 0xc1, 0xaf, 0xbd, 0x03, 0x01, 0x13, 0x8a, 0x6b, 0x3a, 0x91, 0x11, 0x41, 0x4f, 0x67, 0xdc, 0xea, 0x97, 0xf2, 0xcf, 0xce, 0xf0, 0xb4, 0xe6, 0x73, 0x96, 0xac, 0x74, 0x22, 0xe7, 0xad, 0x35, 0x85, 0xe2, 0xf9, 0x37, 0xe8, 0x1c, 0x75, 0xdf, 0x6e, 0x47, 0xf1, 0x1a, 0x71, 0x1d, 0x29, 0xc5, 0x89, 0x6f, 0xb7, 0x62, 0x0e, 0xaa, 0x18, 0xbe, 0x1b, 0xfc, 0x56, 0x3e, 0x4b, 0xc6, 0xd2, 0x79, 0x20, 0x9a, 0xdb, 0xc0, 0xfe, 0x78, 0xcd, 0x5a, 0xf4, 0x1f, 0xdd, 0xa8, 0x33, 0x88, 0x07, 0xc7, 0x31, 0xb1, 0x12, 0x10, 0x59, 0x27, 0x80, 0xec, 0x5f, 0x60, 0x51, 0x7f, 0xa9, 0x19, 0xb5, 0x4a, 0x0d, 0x2d, 0xe5, 0x7a, 0x9f, 0x93, 0xc9, 0x9c, 0xef, 0xa0, 0xe0, 0x3b, 0x4d, 0xae, 0x2a, 0xf5, 0xb0, 0xc8, 0xeb, 0xbb, 0x3c, 0x83, 0x53, 0x99, 0x61, 0x17, 0x2b, 0x04, 0x7e, 0xba, 0x77, 0xd6, 0x26, 0xe1, 0x69, 0x14, 0x63, 0x55, 0x21, 0x0c, 0x7d
};//在一行上進位移 
void rotWord(unsigned char temp[]) {int i,k=temp[0];for(i=1;i<4;i++)temp[i-1]=temp[i];temp[3]=k;
}//在一行上進行s盒替換 
void subWord(unsigned char temp[]) {int i;for(i=0;i<4;i++)temp[i]=SBOX[temp[i]];
}//密鑰擴展,最終得到Nr+1個輪密鑰,用于輪次加密 
void keyExpansion(){int i,j;unsigned char temp[5];memset(RoundKey,0,sizeof(RoundKey));for(i=0;i<Nk;i++){for(j=0;j<4;j++){RoundKey[i*4+j]=Key[i*4+j];}}while(i<(Nb*(Nr+1))){for(j=0;j<4;j++){temp[j]=RoundKey[(i-1)*4+j];}if(i%Nk==0){rotWord(temp);subWord(temp);temp[0]^=Rcon[i/Nk];}for(j=0;j<4;j++)RoundKey[i*4+j]=RoundKey[(i-Nk)*4+j]^temp[j];i++;}
}//輪密鑰加函數,將明文加密狀態與輪密鑰簡單異或 
void addRoundKey(int round){int i,j;for(i=0;i<4;i++){for(j=0;j<4;j++){state[i][j]^=RoundKey[round*Nb*4+i*Nb+j];}}
}//s盒替換函數 
void subBytes(){int i,j;for(i=0;i<4;i++){for(j=0;j<4;j++){state[i][j]=SBOX[state[i][j]];}}
}//逆s盒替換函數 
void invSubBytes(){int i,j;for(i=0;i<4;i++){for(j=0;j<4;j++){state[i][j]=R_SBOX[state[i][j]];}}
}//行位移函數 
void shiftRows(){int i,j,k;int shiftnum=1;unsigned char tmp;for(j=1;j<4;j++){for(i=0;i<shiftnum;i++){tmp=state[0][j];for(k=0;k<3;k++)state[k][j]=state[k+1][j];state[3][j]=tmp;}shiftnum++;}
}//逆行位移函數 
void invShiftRows(){int i,j,k;int shiftnum=1;unsigned char tmp;for(j=1;j<4;j++){for(i=0;i<shiftnum;i++){tmp=state[3][j];for(k=3;k>0;k--)state[k][j]=state[k-1][j];state[0][j]=tmp;}shiftnum++;}
}//列混淆函數 
#define xtime(x)   ((x<<1) ^ (((x>>7) & 1) * 0x1b))
void mixColumns(){int i,j;unsigned char tmp,t,p;for(i=0;i<4;i++){p=state[i][0];tmp=state[i][0]^state[i][1]^state[i][2]^state[i][3];for(j=0;j<3;j++){t=state[i][j]^state[i][j+1];t=xtime(t);state[i][j]^=t^tmp;}t=state[i][3]^p;t=xtime(t);state[i][3]^=t^tmp;}
}//逆列混淆函數 
#define Multiply(x,y) (((y & 1) * x) ^ ((y>>1 & 1) * xtime(x)) ^ ((y>>2 & 1) * xtime(xtime(x))) ^ ((y>>3 & 1) * xtime(xtime(xtime(x)))) ^ ((y>>4 & 1) * xtime(xtime(xtime(xtime(x))))))
void invMixColumns(){int i;unsigned char a,b,c,d;for( i=0; i<4; i++){   a = state[i][0];b = state[i][1];c = state[i][2];d = state[i][3];state[i][0] = Multiply(a, 0x0e) ^ Multiply(b, 0x0b) ^ Multiply(c, 0x0d) ^ Multiply(d, 0x09);state[i][1] = Multiply(a, 0x09) ^ Multiply(b, 0x0e) ^ Multiply(c, 0x0b) ^ Multiply(d, 0x0d);state[i][2] = Multiply(a, 0x0d) ^ Multiply(b, 0x09) ^ Multiply(c, 0x0e) ^ Multiply(d, 0x0b);state[i][3] = Multiply(a, 0x0b) ^ Multiply(b, 0x0d) ^ Multiply(c, 0x09) ^ Multiply(d, 0x0e);}
}//aes加密函數,key為密鑰,input為需要加密的128位明文,output為輸出128位密文 
void aes_enc(unsigned char*key,unsigned char *input,unsigned char*output){int i,j,round=0;memset(Key,0,sizeof(Key));for(i=0;i<Nk*4;i++){Key[i]=key[i];}keyExpansion();memset(state,0,sizeof(state));for(i=0;i<4;i++){for(j=0;j<4;j++)state[i][j]=input[i*4+j];}addRoundKey(0);for(round=1;round<Nr;round++){subBytes();shiftRows();mixColumns();addRoundKey(round);}subBytes();shiftRows();addRoundKey(Nr);for(i=0;i<4;i++){for(j=0;j<4;j++)output[i*4+j]=state[i][j];}
}//aes解密函數,key為密鑰,input為需要解密的128位密文,output為輸出128位明文
void aes_dec(unsigned char*key,unsigned char*input,unsigned char*output){int i,j,round=0;memset(Key,0,sizeof(Key));for(i=0;i<Nk*4;i++){Key[i]=key[i];}keyExpansion();memset(state,0,sizeof(state));for(i=0;i<4;i++){for(j=0;j<4;j++)state[i][j]=input[i*4+j];}addRoundKey(Nr);for(round=Nr-1;round>0;round--){invSubBytes();invShiftRows();addRoundKey(round);invMixColumns();}invSubBytes();	invShiftRows();addRoundKey(0);for(i=0;i<4;i++){for(j=0;j<4;j++)output[i*4+j]=state[i][j];}
}void gets_t(unsigned char*str){char fin_input;scanf("%66s",str);dofin_input=getchar();while(fin_input!='\n');
}int main(){unsigned char key[17]={0};unsigned char input[17]={0};unsigned char enc[17]={0};unsigned char dec[17]={0};printf("input key: ");gets_t(key);printf("input state: ");gets_t(input);aes_enc(key,input,enc);printf("enc:%s\n",enc);aes_dec(key,enc,dec);printf("dec:%s\n",dec);return 0;
}

代碼效果:

總結

以上是生活随笔為你收集整理的C语言实现AES加解密的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

热久久精品在线 | 免费合欢视频成人app | 免费观看福利视频 | 亚洲精品字幕在线 | 久久www免费视频 | 国产一区二区久久精品 | 天天操欧美| 97超级碰碰碰碰久久久久 | 日韩videos| 天天草天天干天天 | 91久久奴性调教 | 亚洲专区路线二 | 日韩一区二区免费播放 | 超碰在线中文字幕 | 在线观看视频一区二区 | 国产精品成人久久久久 | 最近免费中文字幕mv在线视频3 | 最新色站 | 五月天丁香视频 | 精品久久国产精品 | 亚洲永久国产精品 | 国产成人一区二区三区电影 | 日本精品视频在线观看 | 天天天操天天天干 | 免费看黄色毛片 | 久久只精品99品免费久23小说 | 亚洲成av人影片在线观看 | 亚洲精品无 | 久久色亚洲 | 国产精品麻豆免费版 | 五月婷婷综合在线观看 | 亚洲精品一区二区18漫画 | 蜜臀av性久久久久蜜臀aⅴ流畅 | 婷婷综合导航 | 天天干视频在线 | 欧美日韩高清在线 | 国产精品欧美日韩在线观看 | 五月婷婷国产 | 日韩特黄一级欧美毛片特黄 | 欧美精品乱码久久久久 | 看国产黄色片 | 亚洲精品一区二区精华 | 亚洲精品中文字幕视频 | 国产手机视频精品 | 超碰99人人| 人人盈棋牌 | 国产成人免费网站 | 国产精品永久在线观看 | 中文字幕 国产视频 | 国产女人18毛片水真多18精品 | 国产人成精品一区二区三 | 欧美va在线观看 | 久久这里只有精品视频99 | 操久久免费视频 | 91精品国自产在线偷拍蜜桃 | 国产青草视频在线观看 | 国产中文字幕在线 | 福利电影一区二区 | 国产在线精品一区二区不卡了 | 夜色.com| 丝袜制服综合网 | 中文在线www| 久久电影日韩 | 国产精品18久久久久vr手机版特色 | av官网在线| 黄网站免费大全入口 | 五月在线| 国产美女久久 | 中文字幕之中文字幕 | 成人在线免费看视频 | 国产原创在线 | 免费观看久久久 | 中文字幕 第二区 | 国产精品福利av | 亚洲一区日韩在线 | 免费精品久久久 | 天天狠狠 | 在线观看中文字幕 | 在线观看爱爱视频 | 一区二区三区电影 | 日韩精品免费一区二区 | 一区二区视频播放 | 久久99欧美 | 玖玖在线免费视频 | 国精产品满18岁在线 | 日日狠狠| 夜夜操狠狠干 | 色婷婷狠狠五月综合天色拍 | 黄a网| 国精产品999国精产 久久久久 | 又黄又爽的视频在线观看网站 | 黄色视屏免费在线观看 | 黄色网址在线播放 | 久久综合色综合88 | 在线日韩精品视频 | 日本久久片 | 91av亚洲 | 四虎免费在线观看视频 | 在线观看国产成人av片 | 日韩在线观看av | 天天操天天谢 | 91在线视频免费播放 | 亚洲首页| 中文在线a∨在线 | 日本最新高清不卡中文字幕 | 九九久久国产精品 | 精品一区二区免费视频 | 亚洲丝袜中文 | 99久久综合国产精品二区 | 伊人婷婷久久 | 五月婷婷中文网 | 亚州激情视频 | 婷婷av网 | 久久久.com | 日韩av播放在线 | 国产免费视频一区二区裸体 | 久久99精品国产99久久6尤 | 久久好看免费视频 | 欧美性生活免费看 | 在线最新av | 美女网站色免费 | 欧美成a人片在线观看久 | 五月婷婷天堂 | 国产美腿白丝袜足在线av | 激情av资源 | av中文天堂在线 | 午夜18视频在线观看 | 毛片一级免费一级 | 久久久毛片 | 一本一本久久a久久精品牛牛影视 | 国产精品一区二区你懂的 | 中文字幕欧美日韩va免费视频 | 一区二区三区在线免费观看 | 在线播放你懂 | 日韩久久午夜一级啪啪 | 最近最新中文字幕 | .精品久久久麻豆国产精品 亚洲va欧美 | 日韩精品2区| 日日夜夜精品视频天天综合网 | 92国产精品久久久久首页 | 久久精品牌麻豆国产大山 | 五月香婷 | 天天综合网 天天综合色 | 最近中文字幕第一页 | 国产夫妻自拍av | 亚洲专区路线二 | 黄色毛片观看 | 亚洲精品中文字幕在线观看 | 日日爽| 激情综合亚洲 | 欧亚日韩精品一区二区在线 | 九九三级毛片 | 中文字幕在线观看免费观看 | 亚洲欧美视频网站 | 色99视频 | 97超碰人人 | 婷婷伊人综合 | 在线播放日韩av | 日韩久久影院 | 韩国精品一区二区三区六区色诱 | 亚洲电影黄色 | 国产精品福利无圣光在线一区 | 嫩小bbbb摸bbb摸bbb | 亚洲黄色小说网 | 国产精品九九九九九 | 久久国产精品99精国产 | 99精品视频一区 | av动态图片 | 成人久久久久久久久久 | 成人av动漫在线 | 欧美精品久久久久久久亚洲调教 | 成人av一区二区三区 | 国内视频在线 | 欧美日韩伦理一区 | 国产 日韩 欧美 中文 在线播放 | 久久久久久久久久久高潮一区二区 | 国产高清视频免费最新在线 | 91精选在线观看 | 91成人精品一区在线播放69 | 青青河边草免费 | 一区二区三区高清 | 天天躁日日躁狠狠躁av麻豆 | 日本久久久久久久久久 | 一本一本久久a久久精品综合妖精 | 亚洲人成在线观看 | 亚洲国产日韩一区 | 91麻豆传媒| 国产网红在线 | 99色99| 欧美夫妻性生活电影 | 色a综合 | 欧美极品少妇xxxxⅹ欧美极品少妇xxxx亚洲精品 | 亚洲欧美成人 | 五月色综合 | 日本女人逼 | 日日摸日日添日日躁av | 精品久久电影 | 中文成人字幕 | 夜又临在线观看 | 国产香蕉视频在线观看 | 国产一级片一区二区三区 | 日韩精品一区二区三区不卡 | 国产精品综合久久 | 欧美 激情 国产 91 在线 | 成人精品国产免费网站 | 91香蕉亚洲精品 | 成人精品电影 | 玖玖视频国产 | 国精产品999国精产品岳 | 在线不卡视频 | 欧美男同视频网站 | 一区二区三区在线观看免费 | 婷婷草| av在线电影播放 | 国产又粗又猛又色又黄网站 | 午夜精品中文字幕 | 国产福利一区二区在线 | 午夜精品久久久久久久99婷婷 | 91视频免费观看 | 午夜精品一区二区三区免费视频 | 丰满少妇在线 | 色停停五月天 | www.com久久 | 99热九九这里只有精品10 | 日韩动漫免费观看高清完整版在线观看 | 国产精品久久久久免费观看 | 日本中文字幕一二区观 | 日韩有码网站 | 亚洲人av免费网站 | 波多野结衣一区二区 | 亚洲国产中文字幕 | 综合网伊人 | 少妇精69xxtheporn| 精品国产一区二区三区四 | 天堂久久电影网 | 免费三及片 | 久久免费精品一区二区三区 | a级片韩国| 日韩色综合| 毛片激情永久免费 | 黄色av电影 | 性色视频在线 | 国产精品成人免费精品自在线观看 | 日韩久久精品一区二区 | 国产在线精品观看 | 国产精品永久免费 | 国产一级视屏 | 国产91粉嫩白浆在线观看 | 久久国产精品99久久人人澡 | 久要激情网 | 黄色app网站在线观看 | 鲁一鲁影院 | 五月天丁香 | av中文电影 | 人人讲| 麻豆国产露脸在线观看 | 国产日韩在线视频 | 日本最大色倩网站www | 欧美aaa视频| 国产精品video爽爽爽爽 | 国产欧美综合视频 | 国产精品青草综合久久久久99 | 亚洲精品免费播放 | 999视频精品 | 免费看黄色毛片 | 国产精品久久久久久久久久白浆 | 久久综合加勒比 | 国产婷婷视频在线 | 免费观看一级一片 | 免费91麻豆精品国产自产在线观看 | 久草网在线观看 | 99在线观看免费视频精品观看 | 欧美天天射 | 中文字幕在线免费观看视频 | 亚洲精品中文在线资源 | 久久精品—区二区三区 | 欧美 激情 国产 91 在线 | 99国产在线视频 | 一级免费黄色 | 亚洲精品视频在线播放 | 人人澡人人爽 | 色综合久久中文字幕综合网 | 亚洲aaa级| 99综合电影在线视频 | 日韩久久在线 | 日韩爱爱网站 | 午夜成人免费电影 | 狠狠色伊人亚洲综合网站野外 | 日本激情中文字幕 | 在线天堂日本 | 免费久久久 | 国产免费一区二区三区网站免费 | 97理论电影 | 欧美日韩成人一区 | 99久久婷婷国产精品综合 | 成年人免费av | 久久久久久久久毛片精品 | 一区二区在线不卡 | 国产成人在线免费观看 | 五月天久久久久 | 天天干,天天射,天天操,天天摸 | 日韩av资源在线观看 | 中文字幕一区二区三区四区在线视频 | 国产精品美女毛片真酒店 | 精品美女久久 | 美女免费网视频 | 欧美一区二区三区在线看 | 日韩精品中文字幕在线不卡尤物 | 丁香激情综合 | 亚洲 欧美日韩 国产 中文 | 狠狠躁天天躁 | 一区二区三区四区五区在线 | 亚洲最新av网址 | 亚洲成aⅴ人在线观看 | 色偷偷网站视频 | 中文字幕国产一区二区 | 国产一级二级视频 | 米奇影视7777 | 天天操天天干天天操天天干 | 日日爱夜夜爱 | 中文字幕在线观看免费高清完整版 | 亚洲日日射 | av成人黄色| 天天操天天干天天操天天干 | 国产精品视频地址 | 亚洲高清在线精品 | 久久美女免费视频 | 少妇bbw搡bbbb搡bbb | 99国产免费网址 | 中文字幕av网站 | 天天超碰 | 久久96国产精品久久99漫画 | 成人网页在线免费观看 | 日韩精品视频第一页 | 亚洲一区日韩 | 欧美激情操 | 人人爽人人香蕉 | 国产剧情av在线播放 | 婷婷在线资源 | 久久精品一区二区三区中文字幕 | 日韩手机在线观看 | 国产精品毛片一区二区 | 久久av中文字幕片 | mm1313亚洲精品国产 | 日韩一区二区三区在线观看 | 在线视频一区二区 | 深爱开心激情 | 九草视频在线 | 久久精品视频在线观看免费 | 中文一区二区三区在线观看 | 97精品国产97久久久久久 | 欧美aaa级片 | 一区二区三区国产欧美 | 国产精品久久久久久久婷婷 | 国产一区在线观看免费 | 国产一级二级三级在线观看 | 精品国产一区二区三区久久久久久 | 国产精品久久久久久久久免费 | 久久婷婷色综合 | 激情婷婷综合网 | 国产日韩中文字幕 | 久久精品资源 | 欧美污污视频 | 丁香在线 | 久久亚洲私人国产精品va | 五月开心婷婷 | 九九热免费精品视频 | 国产成人精品一区二区 | 91中文字幕在线 | 91看片成人 | 91九色视频观看 | 99视频 | 亚洲日本精品视频 | 亚洲伊人第一页 | 最近日本韩国中文字幕 | 色在线高清 | 日韩黄色大片在线观看 | 丰满少妇麻豆av | 中文字幕电影在线 | 毛片久久久 | 成人影片在线播放 | 久久这里只有精品首页 | 亚洲另类交 | 日韩午夜在线观看 | 中文电影网 | 国产一区视频免费在线观看 | 久久久久久国产精品999 | 91av网站在线观看 | 一区二区三区在线免费 | 日韩高清在线一区二区 | 久久精品免视看 | 日韩av电影国产 | 日韩精品一二三 | 久久a免费视频 | 亚洲成人频道 | 五月综合激情 | 狠狠干婷婷色 | 日本精a在线观看 | 91国内在线 | 久久久久亚洲精品国产 | 国产精品福利在线 | 国产一级电影免费观看 | 国产黄色大片免费看 | 久久超| 亚洲精品综合一区二区 | 国内精品国产三级国产aⅴ久 | av短片在线观看 | 免费在线观看亚洲视频 | 国产伦精品一区二区三区… | 69久久久| 人人澡超碰碰 | 亚洲综合涩 | 国产麻豆剧果冻传媒视频播放量 | 精品国产一区二区三区久久久久久 | 波多野结衣视频一区 | 亚洲天堂首页 | 日韩手机在线 | 国内精品久久久久久久久久久 | 久久精品精品电影网 | 国产中文字幕一区二区 | 在线精品视频在线观看高清 | 99精品国产免费久久久久久下载 | 久草在在线 | 4438全国亚洲精品观看视频 | 国产黄色免费 | 婷婷亚洲最大 | 视频在线99re | 中文字幕在线视频免费播放 | 久久久久国产精品视频 | 一级黄色免费 | av免费黄色| 中文字幕 91 | 最近日本韩国中文字幕 | 欧美一区免费在线观看 | 波多野结衣在线观看视频 | 日韩中文字幕免费在线播放 | 久久综合久久综合九色 | 国产精品孕妇 | 欧美黄污视频 | 麻花豆传媒mv在线观看 | 成年人视频免费在线播放 | 久久国产热视频 | 成人在线网站观看 | 日日摸日日爽 | 国产成人精品久久二区二区 | 麻豆视频免费网站 | 日韩视频在线观看免费 | 韩国av不卡| 五月婷婷电影网 | 国产精品综合久久久久久 | 91亚洲精品久久久中文字幕 | 最近中文字幕免费av | 黄色三级在线观看 | 狂野欧美激情性xxxx欧美 | 色中色亚洲 | 日韩一区二区三区高清免费看看 | 久久国产日韩 | 黄色大全在线观看 | 涩涩成人在线 | 国产大陆亚洲精品国产 | 日韩高清一二区 | 嫩草av在线 | 日韩欧美在线第一页 | 人人爽人人做 | 亚洲视频国产 | 99视频 | 国产麻豆传媒 | 91麻豆福利 | 99精品一区二区三区 | 国产明星视频三级a三级点| 九九热在线免费观看 | 天天干,天天射,天天操,天天摸 | 国产精品久久久久久久99 | 视频1区2区 | 免费看三级 | 五月婷婷av在线 | 久久久黄色免费网站 | 亚洲精品色婷婷 | 天天色天天干天天 | 操碰av | 国产精品资源网 | 午夜电影一区 | 欧美性高跟鞋xxxxhd | 久久涩视频| 欧美污网站 | 国产在线一区二区三区播放 | 亚洲精品88欧美一区二区 | 日韩成人免费在线观看 | 青青河边草免费观看完整版高清 | 在线观看一 | www黄色软件 | 欧美一级在线 | 国产成人免费高清 | 一级电影免费在线观看 | 美女一区网站 | 亚洲国产成人在线观看 | www.色国产 | 亚洲天堂精品视频在线观看 | 97视频免费看| 日韩理论在线 | 日韩久久精品一区二区三区下载 | 婷婷综合导航 | 日韩精品一区二区在线观看视频 | 开心婷婷色 | 韩国精品视频在线观看 | 99精品视频免费在线观看 | 国产自产高清不卡 | 韩国一区二区三区视频 | 免费看十八岁美女 | 色婷婷伊人 | 久久综合激情 | 中文字幕在线视频一区二区 | 在线看福利av | 欧美日韩二区在线 | 亚洲一区不卡视频 | 久久精品一区二区三区四区 | 日日干夜夜骑 | 91成人精品在线 | 久久久久久久久毛片精品 | 中文字幕在线视频一区二区 | 超碰97在线资源 | 日韩视频一区二区 | 欧美美女激情18p | 亚洲免费国产视频 | 国产一级淫片在线观看 | 国产手机在线视频 | 亚洲欧美成人网 | 国产护士hd高朝护士1 | 在线精品视频在线观看高清 | 91超碰在线播放 | 国产精品夜夜夜一区二区三区尤 | v片在线播放 | 久久6精品 | 亚洲黄色三级 | 久久久久久久久久久久99 | 91成人在线看 | 欧洲一区二区在线观看 | 精品国产电影 | 久久免费福利视频 | 日韩,中文字幕 | 一区二区三区四区五区在线视频 | 国产美女精品人人做人人爽 | 日韩最新av在线 | 91人人澡人人爽人人精品 | 在线看岛国av | 午夜.dj高清免费观看视频 | 国产精品9999久久久久仙踪林 | 最近中文字幕大全中文字幕免费 | 亚洲最新视频在线 | 一级淫片a | 91精品夜夜 | 国产免费视频一区二区裸体 | 国产精品女| 日韩综合色 | 天天操夜夜操国产精品 | 亚洲国内精品在线 | 久久观看免费视频 | 精久久久久 | 91在线视频在线 | 在线观看日韩国产 | 在线视频 区 | 久久午夜网 | av免费试看 | 久久爱资源网 | 国产精品久久久久久久久久新婚 | 日日爱网址 | 欧美日韩国产免费视频 | 欧美另类一二三四区 | 视频1区2区 | 国产精品爽爽久久久久久蜜臀 | 日日添夜夜添 | 蜜桃麻豆www久久囤产精品 | 中文字幕在线观看完整版 | 国产韩国日本高清视频 | 精油按摩av | 国产精品一区二区久久精品爱涩 | 亚洲天堂社区 | www.久艹| 中文字幕日韩国产 | 美女在线免费观看视频 | 国产精品99久久久久久武松影视 | 一级一片免费观看 | 国产精品一区二区在线观看 | 国产精品免费视频观看 | 亚洲精品小视频 | 操处女逼 | 另类老妇性bbwbbw高清 | 久久久99精品免费观看 | 亚洲精品久久久久中文字幕m男 | 成人影音av | 久久视频在线看 | 97超碰在线资源 | 韩国av免费在线 | 日韩免费三区 | 国产成人高清av | 成人久久 | 色www免费视频 | 992tv人人草 黄色国产区 | 96精品高清视频在线观看软件特色 | 午夜av电影| 国产精品久久久久久一二三四五 | 久久看免费视频 | 香蕉视频在线免费 | 欧美在线91 | 免费久久网站 | 国产成人一区二区三区 | 免费看国产视频 | 深爱激情站 | 波多野结衣电影一区二区三区 | 91大神精品视频在线观看 | 在线视频a | 国产91全国探花系列在线播放 | 欧美激情视频免费看 | 久久久不卡影院 | 午夜精品一区二区三区在线观看 | 久久成人麻豆午夜电影 | 特级西西444www大胆高清无视频 | 99久久久国产精品美女 | 亚洲播放一区 | 国产高清黄色 | 亚色视频在线观看 | 久久免费精品一区二区三区 | 国产理论一区二区三区 | 亚洲一级性| 一区二区三区精品久久久 | 在线观看黄污 | 成人免费在线播放 | 福利一区二区三区四区 | 色婷婷骚婷婷 | 99久久久久久久久久 | 亚洲精品在线观看网站 | 在线观看亚洲电影 | 热久久国产精品 | 日日干夜夜爱 | 日韩激情小视频 | 欧美狠狠操 | 免费成人在线观看视频 | 九九久久婷婷 | 亚洲精品影院在线观看 | 婷婷综合网 | 欧美成a人片在线观看久 | 国产精品久久久久久欧美 | 亚洲国产剧情av | 亚洲人xxx | 国产精品一区二区三区在线免费观看 | 午夜久久美女 | 国产91精品一区二区麻豆亚洲 | 亚洲视频免费在线观看 | 日韩在线免费高清视频 | 亚洲专区免费观看 | 久久精品五月 | 成人av在线电影 | 丁香五香天综合情 | 日韩成人免费在线 | 午夜丰满寂寞少妇精品 | 国产亚洲永久域名 | 精品免费国产一区二区三区四区 | 97超碰人人澡人人爱 | 92中文资源在线 | 色吊丝在线永久观看最新版本 | 91av美女| 日韩激情视频在线观看 | 午夜久久福利视频 | 成片免费观看视频 | 少妇高潮流白浆在线观看 | 国内偷拍精品视频 | 黄色免费网战 | 伊香蕉大综综综合久久啪 | 人人草天天草 | 免费中文字幕视频 | 国产在线 一区二区三区 | 免费国产一区二区视频 | 九九热视频在线免费观看 | 欧美-第1页-屁屁影院 | 日韩av美女 | 激情久久久久久久久久久久久久久久 | 中文字幕2021 | 碰超人人 | 日本黄色免费看 | 国产色婷婷精品综合在线手机播放 | 91色国产在线 | 99日精品| 在线观看日韩精品 | 久久激情片 | 久久精品视频在线观看 | 免费视频成人 | 蜜臀av夜夜澡人人爽人人 | 91av在线视频免费观看 | 在线免费高清一区二区三区 | 亚洲精品免费在线观看 | 天天操天天摸天天射 | 欧美日韩中文字幕在线视频 | 欧美ⅹxxxxxx| 91xav| 欧美 激情在线 | 黄色在线观看网站 | 日韩中文字幕在线 | 波多野结依在线观看 | 国产日韩精品一区二区三区 | 九色精品免费永久在线 | av在线专区| 日韩免费在线视频 | 免费网站黄色 | 色窝资源 | 久久免费看a级毛毛片 | av超碰免费在线 | 最新久久久 | 国产成人高清av | 777奇米四色| 中文字幕资源在线观看 | 黄色www| 啪嗒啪嗒免费观看完整版 | 中文在线亚洲 | 97视频在线观看网址 | 97视频网站 | 中文字幕在线影视资源 | 日韩乱码中文字幕 | 欧美性成人 | 天天色天天干天天 | 国产精品99在线播放 | 久久久国产精华液 | 亚洲a免费| 99精品视频在线观看播放 | 成人av av在线 | 亚洲欧美日韩精品一区二区 | 射久久| 毛片激情永久免费 | 干天天 | 狠狠操操网 | 国产系列 在线观看 | 国产69精品久久久久9999apgf | 激情综合网色播五月 | 久久综合九色综合网站 | 色播99 | 日日夜色 | 国产精品久久久免费 | 干天天 | 日韩免费小视频 | 亚洲午夜小视频 | 国产美女精品人人做人人爽 | 中文字幕日韩有码 | 亚洲一区日韩 | 久久免费一级片 | 热久久免费国产视频 | 免费看污的网站 | 国产精品系列在线播放 | av不卡免费在线观看 | 白丝av免费观看 | 亚洲欧美日韩国产精品一区午夜 | 久久精品91久久久久久再现 | 国产美女精品视频免费观看 | 日韩黄色中文字幕 | 天天色天天爱天天射综合 | 中文字幕频道 | 久久精品视频播放 | 黄色视屏在线免费观看 | 亚洲va天堂va欧美ⅴa在线 | 欧洲精品视频一区二区 | 免费网址在线播放 | 日韩精品你懂的 | 国产精品免费不卡 | 久久久久久久久久久久久久免费看 | 日韩精品一区二区三区免费视频观看 | 涩五月婷婷| 亚洲成人精品av | 91桃色在线免费观看 | 超碰夜夜| 天天操狠狠操 | 久久综合之合合综合久久 | 中文字幕 影院 | 四虎在线免费 | 欧美日韩免费在线视频 | av在线官网 | 337p日本大胆噜噜噜噜 | 91精品免费在线视频 | 亚洲综合小说 | 久久久久蜜桃 | 国产三级国产精品国产专区50 | 麻豆视频观看 | 久久一区二区三区超碰国产精品 | 日韩欧美高清在线观看 | 亚洲精品小视频 | 日韩av电影手机在线观看 | 亚洲精品视频一 | 国产91av视频在线观看 | 国产精品爽爽爽 | 国产成人综合精品 | 国产中文字幕在线播放 | 人人看人人 | 国产精品入口久久 | 天天操天天舔天天爽 | 五月天com | 黄色a级片在线观看 | 亚洲激情 在线 | 超碰人人舔| 99视频精品视频高清免费 | 亚洲精品乱码久久久久久按摩 | 亚洲美女在线一区 | 91探花在线视频 | 中文字幕免费成人 | 国内精品久久久久影院一蜜桃 | 国产成人综合在线观看 | 国产精品2018 | 久久电影色| 久久综合久色欧美综合狠狠 | 亚洲va在线va天堂 | 韩国一区视频 | 成人看片 | 中文字幕视频免费观看 | 国产精品久久久久国产a级 激情综合中文娱乐网 | 一区二精品 | 日韩一级黄色大片 | 日日日操操 | 久久免费福利 | 国产成人精品综合 | 九色91在线视频 | 久热免费在线观看 | 欧美日bb | 又爽又黄又无遮挡网站动态图 | 久久国产高清 | 久久久精品国产一区二区电影四季 | 久草精品在线观看 | 国产91精品看黄网站在线观看动漫 | 久久久久这里只有精品 | 狠狠色丁香婷婷综合最新地址 | 亚洲国产综合在线 | 色妞久久福利网 | 日韩欧美高清免费 | 国产视频一区二区在线播放 | 六月丁香婷婷网 | 精品99久久久久久 | 成人精品一区二区三区中文字幕 | 欧美成人理伦片 | 在线免费色视频 | 亚洲人人av | 91九色性视频| 精品999在线 | 国产高清视频在线播放一区 | 亚洲成人国产 | 中文字幕免费高 | 又黄又爽又刺激的视频 | 中文国产字幕 | 午夜在线免费观看 | 国产在线污 | 尤物一区二区三区 | 精品麻豆入口免费 | 国产精品99久久久久久小说 | 婷婷丁香六月天 | 成年人免费在线 | 国产精品一区电影 | 亚洲最新在线视频 | 免费看一级特黄a大片 | 三级av片| 五月天伊人| 99热这里有 | 国产精品美女在线 | 西西44人体做爰大胆视频 | 免费av在线网站 | 久久婷亚洲五月一区天天躁 | 高清一区二区三区av | 丁香六月中文字幕 | 日韩av手机在线看 | 国产亚洲久一区二区 | 黄色免费电影网站 | 91一区二区三区在线观看 | 日本三级不卡视频 | 久久久久久久国产精品视频 | 婷婷国产精品 | 亚洲视频一| 特级片免费看 | 伊香蕉大综综综合久久啪 | 欧美日韩一级视频 | 在线观看免费色 | 久久久免费看视频 | 国产群p | 亚洲狠狠婷婷 | 国产高清在线精品 | 激情视频免费在线观看 | 免费看黄色小说的网站 | 日本久久久亚洲精品 | 午夜精品一区二区三区在线播放 | 欧美国产视频在线 | 亚州av一区 | 久久久久国产精品一区 | 中文字幕av有码 | 精品国产伦一区二区三区 | 日韩av免费在线看 | 视频一区二区国产 | 久久久国产精华液 | 在线观看亚洲a | 三级在线视频播放 | 美女免费视频网站 | 色婷婷视频在线观看 | 97视频在线播放 | 久久婷婷丁香 | 免费视频你懂得 | 91精品国产成人 | 国产美女黄网站免费 | 粉嫩高清一区二区三区 | 夜夜躁日日躁狠狠躁 | 激情婷婷丁香 | 在线免费黄色av | 天天操天天操天天干 | 69亚洲乱 | 成人资源在线 | 开心激情婷婷 | 国产日产精品久久久久快鸭 | 在线看的毛片 | 天天爽人人爽夜夜爽 | 久久成人黄色 | 青青草国产成人99久久 | 成人一区影院 | 97人人模人人爽人人喊中文字 | 大型av综合网站 | 最近中文字幕国语免费高清6 | 亚洲精品视频免费 | 91传媒免费观看 | 亚洲午夜精品一区二区三区电影院 | 国产精品18久久久久久首页狼 | 亚洲最大免费成人网 | 人人爽久久久噜噜噜电影 | 国产综合在线视频 | 人人澡人人添人人爽一区二区 | 欧美电影在线观看 | 午夜精品一区二区三区免费视频 | 99精品热视频只有精品10 | 伊人狠狠操 | 超碰av在线播放 | 视频在线观看99 | 久久免费的精品国产v∧ | 久草精品视频在线看网站免费 | 色 免费观看| 国产高清视频色在线www | 午夜av激情 | 欧美a级在线免费观看 | 天天av资源 | 久久精品99久久久久久 | 免费三级大片 | 亚洲在线黄色 | 精品成人免费 | 不卡av免费在线观看 | 91成人看片 | 日韩在线小视频 | 91久久一区二区 | 尤物九九久久国产精品的分类 | 国产91全国探花系列在线播放 | 美女视频黄在线 | 精品福利网站 | 91在线视频免费观看 | 97视频免费在线看 | 99视频这里有精品 | 亚洲影院色 | 日韩一级理论片 | 欧美日韩不卡一区 | 青青射| 中文字幕亚洲高清 | 色午夜 | 超碰资源在线 | 婷婷99| 麻豆一级视频 | 国产精品色婷婷视频 | 又紧又大又爽精品一区二区 | 在线观看精品 | 免费看一及片 | 国产亚洲情侣一区二区无 | 国内精品99 | 久久在线免费 | 欧美aa在线 | 女人18片毛片90分钟 | 日韩中文字幕免费视频 | 亚洲亚洲精品在线观看 | 日韩在线视频观看免费 | 在线看片日韩 | 最近av在线 | 999视频在线观看 | 中文字幕电影在线 | 亚洲一区免费在线 | 国产免费观看视频 | 日韩精品一区电影 | 久久久视频在线 | 国产99久久久国产精品成人免费 | 91精品在线免费 | 97免费视频在线 | 国产91成人在在线播放 | 美女视频国产 | 亚洲国产精品免费 | 国产精品系列在线 | 日韩欧美一区二区三区在线 | 日韩三级视频在线看 | 亚洲成人免费在线观看 | 免费视频18 | av在线播放免费 | 久久久久久久久久久久av | 亚洲干视频在线观看 | a成人在线| 成人黄在线| 亚洲欧美日韩一二三区 | 一本一道久久a久久综合蜜桃 |