void encryptCBC(int data[],int dsize,int iv[]){ //暗号化
int tmp[4];
int i,j;
KeyExpansion(key);
for (i = 0; i < dsize; i += 4) {
memcpy(tmp,&data[i],16);
for(j=0;j<4;j++){
tmp[j]^=iv[j]; //16バイトごとに区切ったデータとベクタの排他的論理和
}
Cipher(tmp); //暗号化
memcpy(&data[i],tmp,16);
memcpy(iv,tmp,16); //ベクタの更新
}
}
void decryptCBC(int data[],int dsize,int iv[]){ //復号
int tmp[4];
int v[4];
int i,j;
KeyExpansion(key);
for (i = 0; i < dsize; i += 4) {
memcpy(tmp,&data[i],16);
invCipher(tmp); //復号
if(i==0){ //初期ベクタとの排他的論理和
for(j=0;j<4;j++){
tmp[j]^=iv[j];
}
}else{ //更新したベクタとの排他的論理和
for (j=0;j<4;j++){
tmp[j]^=v[j];
}
}
memcpy(v,&data[i],16); //ベクタの更新
memcpy(&data[i],tmp,16);
}
}
AESのCBCモードでの暗号化、復号を実装しようとしています。
2ブロック目以降は正しく復号できているのですが、1ブロック目が元の値に戻りません。
どこが間違っているかどなたか教えていただけないでしょうか?
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- C言語・C++・C# c言語の問題です 課題1 (二分探索木とセット) 大きさ size の配列 array を考える。す 2 2023/01/10 21:08
- C言語・C++・C# 質問です 下記のコードを分かりやすく解説お願いします 初心者です #include ‹stdio.h 3 2022/05/26 22:03
- C言語・C++・C# C言語プログラム変更 2 2022/12/21 15:03
- C言語・C++・C# 10個の実数に対する降順ソート結果を出力するプログラムを作りたいのですが、以下のプログラムをどう直せ 1 2022/07/09 22:16
- Visual Basic(VBA) vba 重複データ合算 5 2023/07/05 18:55
- Excel(エクセル) エクセルVBAでオブジェクトが必要です 2 2022/09/10 16:37
- C言語・C++・C# プログラミング c言語 4 2023/03/07 01:05
- C言語・C++・C# LU分解法のピボッティングについて(C言語/gcc-9) 3 2022/07/11 23:10
- C言語・C++・C# c言語の問題です 3 2023/01/10 16:15
- C言語・C++・C# C言語 プログラミング 4 2022/05/22 11:53
関連するカテゴリからQ&Aを探す
おすすめ情報
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
複数桁10進数の*桁目だけを抽出...
-
「指定されたキャストは有効で...
-
C言語での引数の省略方法
-
#define _CRT_SECURE_NO_WARNIN...
-
(int *)の意味
-
数字列を3桁ごとにカンマで区切...
-
比較回数と交換回数表示について
-
if と配列の組み合わせ
-
C言語で三目並べをするプログラ...
-
実数の整数部,小数部の取得
-
卒業研究でよく分からないとこ...
-
C言語で分からないところがあり...
-
C言語での奇数の和
-
アスタリスクで正方形
-
警告 W8065について。
-
入力された2つの整数の差を絶対...
-
【C++】関数ポインタの使い方
-
C言語 エラーの原因がわからな...
-
C言語
-
C言語初心者です、、、お助けく...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
「指定されたキャストは有効で...
-
C言語での引数の省略方法
-
複数桁10進数の*桁目だけを抽出...
-
#define _CRT_SECURE_NO_WARNIN...
-
ラップ関数とはどんなものですか?
-
卒業研究でよく分からないとこ...
-
【C++】関数ポインタの使い方
-
実数の整数部,小数部の取得
-
std::set<int> で、ある値が何...
-
C言語 エラーの原因がわからな...
-
c言語
-
system関数がうまくいかない
-
C++でvectorにテキストファイル...
-
acceptをalarmでタイムアウトさ...
-
if と配列の組み合わせ
-
return 1L
-
「{ } で囲むだけ」は正しい?
-
(マルチスレッド)_beginthrea...
-
PowerShellがうまくいかない
-
このプログラミング誰か教えて...
おすすめ情報