亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? rijndaeltest_ref.dpr

?? Rijndael algorithm修正了CBC下BUG的版本(有源代碼)工作在:D5。作者:Sergey Kirichenko。
?? DPR
?? 第 1 頁 / 共 2 頁
字號:
{* rijndaeltest_ref   v2.0   August '99 *}

(* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
 *                ---------------------------------                *
 *                            DELPHI                               *
 *         Implementation of the Known Answer Tests (KAT)          *
 *                   and Monte Carlo Test (MCT)                    *
 *                ---------------------------------                *
 *                                                   December 2000 *
 *                                                                 *
 * Authors: Paulo Barreto                                          *
 *          Vincent Rijmen                                         *
 *                                                                 *
 * Delphi translation by Sergey Kirichenko (ksv@cheerful.com)      *
 *                                                                 *
 * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *)


program rijndaeltest_ref;
{$APPTYPE CONSOLE}

{$define TRACE_KAT_MCT}

uses
  SysUtils,
  rijndael_api_ref;

const
  SUBMITTER = 'Joan Daemen';

function iif(bExpression: boolean; iResTrue,iResFalse: integer): integer;
begin
  if bExpression then
    result:= iResTrue
  else
    result:= iResFalse;
end;

function iif2(bExpression: boolean; sResTrue, sResFalse: string): string;
begin
  if bExpression then
    result:= sResTrue
  else
    result:= sResFalse;
end;

procedure wait;
begin
  write('* hit <enter> to exit...'); readln; writeln;
end;

procedure haltwait;
begin
  wait; halt;
end;

procedure blockPrint(var fp: textfile; const block: pBYTE; blockBits: integer; tag: string);
var
  i: integer;
begin
  write(fp, format('%s=',[tag]));
  for i:= 0 to (blockBits div 8)-1 do
    write(fp, format('%.2X',[block[i]]));
  writeln(fp,'');
  flush(fp);
end; {* blockPrint *}

procedure HexToBin(binBlock: pBYTE; const hexBlock: pchar; blockLen: integer);
var
  i,k,j,t: integer;
begin
  j:= 0;
  i:= 0;
  k:= 0;
  while (blockLen > 0) do
    begin
      t:= integer(hexBlock[i]);
      inc(i);
      if ((t >= ord('0')) and (t <= ord('9'))) then
        j:= (t - ord('0')) shl 4
      else
        if ((t >= ord('a')) and (t <= ord('f'))) then
          j:= (t - ord('a') + 10) shl 4
        else
          if ((t >= ord('A')) and (t <= ord('F'))) then
            j:= (t - ord('A') + 10) shl 4;

      t:= integer(hexBlock[i]);
      inc(i);
      if ((t >= ord('0')) and (t <= ord('9'))) then
        j:= j xor (t - ord('0'))
      else
        if ((t >= ord('a')) and (t <= ord('f'))) then
          j:= j xor (t - ord('a') + 10)
        else
          if ((t >= ord('A')) and (t <= ord('F'))) then
            j:= j xor (t - ord('A') + 10);

    binBlock[k]:= j;
    inc(k);
    blockLen:= blockLen- 8;
  end;
end; {* HexToBin *}

procedure rijndaelVKKAT(var fp: textfile; keyLength, blockLength: integer);
var
  i, j, r: integer;
  block: array [0..(4*MAXBC)-1] of BYTE;
  keyMaterial: array [0..320-1] of BYTE;
  byteVal: BYTE;
  keyInst: TkeyInstance;
  cipherInst: TcipherInstance;
begin
  byteVal:= BYTE('8');
{$ifdef TRACE_KAT_MCT}
  write(format('Executing Variable-Key KAT (key %d): ',[keyLength]));
{$endif} // ?TRACE_KAT_MCT
  write(fp,format(#13+#10+
		'=========='+#13+#10+
		#13+#10+
		'KEYSIZE=%d'+#13+#10+
		#13+#10,[keyLength]));
  flush(fp);
  FillChar(block, blockLength div 8, 0); // memset
  blockPrint(fp, addr(block), blockLength, 'PT');
  FillChar(keyMaterial, sizeof(keyMaterial),0);
  FillChar(keyMaterial, keyLength div 4,'0');
  for i:= 0 to keyLength-1 do
    begin
      keyMaterial[i div 4]:= byteVal; { set only the i-th bit of the i-th test key }
      keyInst.blockLen:= blockLength;
      r:= makeKey(addr(keyInst), DIR_ENCRYPT, keyLength, addr(keyMaterial));
      if (rTRUE <> r)  then
        begin
          writeln(format('makeKey error %d',[r]));
          haltwait; //(-1);
        end;
      writeln(fp, format(#13+#10+'I=%d', [i+1]));
      writeln(fp, format('KEY=%s',[StrPas(addr(keyMaterial))]));
      FillChar(block, blockLength div 8, 0);
      cipherInst.blockLen:= blockLength;
      r:= cipherInit(addr(cipherInst), MODE_ECB, nil);
      if (rTRUE <> r) then
        begin
          writeln(format('cipherInit error %d',[r]));
          haltwait; //(-1);
        end;
      r:= blocksEnCrypt(addr(cipherInst), addr(keyInst), addr(block), blockLength, addr(block));
      if (blockLength <> r) then
        begin
          writeln(format('blockEncrypt error %d',[r]));
          haltwait; //(-1);
        end;
      blockPrint(fp, addr(block), blockLength, 'CT');
      { now check decryption: }
      keyInst.blockLen:= blockLength;
      makeKey(addr(keyInst), DIR_DECRYPT, keyLength, addr(keyMaterial));
      blocksDeCrypt(addr(cipherInst), addr(keyInst), addr(block), blockLength, addr(block));
      for j:= 0 to (blockLength div 8)-1 do
        begin
          assert(block[j] = 0);      {!debug!}
        end;
      { undo changes for the next iteration: }
      keyMaterial[i div 4]:= BYTE('0');
      byteVal:=
        iif(byteVal = ord('8'), ord('4'),
        iif(byteVal = ord('4'), ord('2'),
        iif(byteVal = ord('2'), ord('1'),
        {(byteVal == '1')} ord('8'))));
    end;
  assert(byteVal = BYTE('8'));      {!debug!}
{$ifdef TRACE_KAT_MCT}
  writeln(' done.');
{$endif} // ?TRACE_KAT_MCT
end; {* rijndaelVKKAT *}

procedure rijndaelVTKAT(var fp: textfile; keyLength, blockLength: integer);
var
  i: integer;
  block: array [0..(4*MAXBC)-1] of BYTE;
  keyMaterial: array [0..320-1] of BYTE;
  keyInst: TkeyInstance;
  cipherInst: TcipherInstance;
begin
{$ifdef TRACE_KAT_MCT}
  write(format('Executing Variable-Text KAT (key %d): ',[keyLength]));
{$endif} // ?TRACE_KAT_MCT
  writeln(fp,format(#13+#10+
		'=========='+#13+#10+
		#13+#10+
		'KEYSIZE=%d'+#13+#10
		,[keyLength]));
  flush(fp);
  FillChar(keyMaterial, sizeof(keyMaterial), 0);
  FillChar(keyMaterial, keyLength div 4, '0');
  keyInst.blockLen:= blockLength;
  makeKey(addr(keyInst), DIR_ENCRYPT, keyLength, addr(keyMaterial));
  writeln(fp,format('KEY=%s',[StrPas(addr(keyMaterial))]));
  for i:= 0 to blockLength-1 do
    begin
      FillChar(block, blockLength div 8, 0);
      block[i div 8]:= block[i div 8] or (1 shl (7 - i mod 8)); { set only the i-th bit of the i-th test block }
      writeln(fp,format(#13+#10+'I=%d',[i+1]));
      blockPrint(fp, addr(block), blockLength, 'PT');
      cipherInst.blockLen:= blockLength;
      cipherInit(addr(cipherInst), MODE_ECB, nil);
      blocksEnCrypt(addr(cipherInst), addr(keyInst), addr(block), blockLength, addr(block));
      blockPrint(fp, addr(block), blockLength, 'CT');
    end;
{$ifdef TRACE_KAT_MCT}
  writeln(' done.');
{$endif} // ?TRACE_KAT_MCT
end;

procedure rijndaelTKAT(var fp: textfile; blockLength, keyLength: integer; var fin: textfile);
var
  i, j: integer;
  s: Cardinal; //unsigned int
  block,block2: array [0..(4*MAXBC)-1] of BYTE;
  keyMaterial: array [0..320-1] of BYTE;
  keyInst: TkeyInstance;
  cipherInst: TcipherInstance;
  ch1,ch2: char;
begin
{$ifdef TRACE_KAT_MCT}
  write(format('Executing Tables KAT (key %d): ',[keyLength]));
{$endif} // ?TRACE_KAT_MCT
  writeln(fp,format(#13+#10+
		'=========='+#13+#10+
		#13+#10+
		'KEYSIZE=%d'+
                #13+#10
		,[keyLength]));
  flush(fp);

  FillChar(keyMaterial, sizeof(keyMaterial), 0);
  for i:= 0 to 64-1 do
    begin
      writeln(fp,format(#13+#10+'I=%d', [i+1]));
      for j:= 0 to (keyLength div 4)-1 do
        read(fin,char(keyMaterial[j]));
      keyInst.blockLen:= blockLength;
      makeKey(addr(keyInst), DIR_ENCRYPT, keyLength, addr(keyMaterial));

      writeln(fp,format('KEY=%s',[StrPas(addr(keyMaterial))]));
      for j:= 0 to (blockLength div 8)-1 do
        begin
          read(fin,ch1);
          read(fin,ch1);
          read(fin,ch2);
          s:= strtoint('$'+ch1+ch2);
          block[j]:= s;
        end;
      readln(fin);
      blockPrint(fp, addr(block), blockLength, 'PT');
      cipherInst.blockLen:= blockLength;
      cipherInit(addr(cipherInst), MODE_ECB, nil);
      blocksEnCrypt(addr(cipherInst), addr(keyInst), addr(block), blockLength, addr(block2));
      blockPrint(fp, addr(block2), blockLength, 'CT');
    end;
  for i:= 64 to 128-1 do
    begin
      writeln(fp, format(#13+#10+'I=%d',[i+1]));
      for j:= 0 to (keyLength div 4)-1 do
        read(fin,char(keyMaterial[j]));
      keyInst.blockLen:= blockLength;
      makeKey(addr(keyInst), DIR_DECRYPT, keyLength, addr(keyMaterial));

      writeln(fp,format('KEY=%s',[StrPas(addr(keyMaterial))]));
      for j:= 0 to (blockLength div 8)-1 do
        begin
          read(fin,ch2);
          read(fin,ch1);
          read(fin,ch2);
          s:= strtoint('$'+ch1+ch2);
          block[j]:= s;
        end;
      readln(fin);
      cipherInst.blockLen:= blockLength;
      cipherInit(addr(cipherInst), MODE_ECB, nil);
      blocksDeCrypt(addr(cipherInst), addr(keyInst), addr(block), blockLength, addr(block2));
      blockPrint(fp, addr(block2), blockLength, 'PT');
      blockPrint(fp, addr(block), blockLength, 'CT');
    end;

{$ifdef TRACE_KAT_MCT}
  writeln(' done.');
{$endif} // ?TRACE_KAT_MCT
end;

procedure rijndaelIVKAT(var fp: textfile; keyLength, blockLength: integer);
var
  i, ROUNDS: integer;
  block,block2: array [0..(4*MAXBC)-1] of BYTE;
  keyMaterial: array [0..320-1] of BYTE;
  keyInst: TkeyInstance;
  cipherInst: TcipherInstance;
begin

{$ifdef TRACE_KAT_MCT}
  write(format('Executing Intermediate value KAT (key %d): ',[keyLength]));
{$endif} // ?TRACE_KAT_MCT

  case iif(keyLength >= blockLength, keyLength, blockLength) of
    128: ROUNDS:= 10;
    192: ROUNDS:= 12;
    256: ROUNDS:= 14;
    else
      exit; { this cannot happen }
  end;

  writeln(fp,format(#13+#10+
		'=========='+#13+#10+
		#13+#10+
		'KEYSIZE=%d',
		[keyLength]));
  flush(fp);
  FillChar(keyMaterial, sizeof(keyMaterial), 0);
  for i:= 0 to (keyLength div 8)-1 do
    StrLCopy(addr(keyMaterial[2*i]),pchar(format('%.2X',[i])),2);
  keyInst.blockLen:= blockLength;
  makeKey(addr(keyInst), DIR_ENCRYPT, keyLength, addr(keyMaterial));
  writeln(fp, format('KEY=%s', [StrPas(addr(keyMaterial))]));
  writeln(fp, #13+#10+'Intermediate Ciphertext Values (Encryption)'+#13+#10);
  for i:= 0 to (blockLength div 8)-1 do
    block[i]:= i;
  blockPrint(fp, addr(block), blockLength, 'PT');
  cipherInst.blockLen:= blockLength;
  cipherInit(addr(cipherInst), MODE_ECB, nil);
  for i:= 1 to ROUNDS-1 do
    begin
      cipherUpdateRounds(addr(cipherInst), addr(keyInst), addr(block), blockLength div 8, addr(block2), i);
      blockPrint(fp, addr(block2), blockLength, format('CT%d',[i]));
    end;
  cipherUpdateRounds(addr(cipherInst), addr(keyInst), addr(block), blockLength, addr(block2), ROUNDS);
  blockPrint(fp, addr(block2), blockLength, 'CT');

  keyInst.blockLen:= blockLength;
  makeKey(addr(keyInst), DIR_DECRYPT, keyLength, addr(keyMaterial));
  writeln(fp, #13+#10+'Intermediate Ciphertext Values (Decryption)'+#13+#10);
  blockPrint(fp, addr(block2), blockLength, 'CT');
  cipherInst.blockLen:= blockLength;
  cipherInit(addr(cipherInst), MODE_ECB, nil);
  for i:= 1 to ROUNDS-1 do
    begin
      cipherUpdateRounds(addr(cipherInst), addr(keyInst), addr(block2), blockLength, addr(block), ROUNDS-i);
      blockPrint(fp, addr(block), blockLength, format('PT%d',[i]));
    end;
  cipherUpdateRounds(addr(cipherInst), addr(keyInst), addr(block2), blockLength, addr(block), 0);
  blockPrint(fp, addr(block), blockLength, 'PT');

{$ifdef TRACE_KAT_MCT}
  writeln(' done.');
{$endif}
end;

procedure makeKATs(const vkFile, vtFile, tblFile, ivFile: string);
var
  fp, fp2: textfile;
begin
  { prepare Variable Key Known Answer Tests: }
  AssignFile(fp,vkFile);
  rewrite(fp);           // write mode
  writeln(fp,format(#13+#10+
		'========================='+#13+#10+
		#13+#10+
		'FILENAME:  "%s"'+#13+#10+
		#13+#10+
		'Electronic Codebook (ECB) Mode'+#13+#10+
		'Variable Key Known Answer Tests'+#13+#10+
		#13+#10+
		'Algorithm Name: Rijndael'+#13+#10+
		'Principal Submitter: %s',
		[vkFile,SUBMITTER]));
  flush(fp);

  rijndaelVKKAT(fp, 128, BITSPERBLOCK); { test for 128-bit key }
  rijndaelVKKAT(fp, 192, BITSPERBLOCK); { test for 192-bit key }
  rijndaelVKKAT(fp, 256, BITSPERBLOCK); { test for 256-bit key }

  write(fp,#13+#10+'==========');
  CloseFile(fp);

  { prepare Variable Text Known Answer Tests: }
  AssignFile(fp,vtFile);
  rewrite(fp);           // write mode
  writeln(fp,format(#13+#10+
		'========================='+#13+#10+
		#13+#10+
		'FILENAME:  "%s"'+#13+#10+
		#13+#10+
		'Electronic Codebook (ECB) Mode'+#13+#10+
		'Variable Text Known Answer Tests'+#13+#10+
		#13+#10+
		'Algorithm Name: Rijndael'+#13+#10+
		'Principal Submitter: %s',
		[vtFile,SUBMITTER]));
  flush(fp);

  rijndaelVTKAT(fp, 128, BITSPERBLOCK);
  rijndaelVTKAT(fp, 192, BITSPERBLOCK);
  rijndaelVTKAT(fp, 256, BITSPERBLOCK);

  write(fp,#13+#10+'==========');
  CloseFile(fp);

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产精品视频免费看| 中文字幕亚洲成人| 99精品欧美一区| 91在线一区二区| 精品制服美女久久| 性久久久久久久久| 国产视频一区二区三区在线观看| 精品视频在线看| 不卡欧美aaaaa| 黄色小说综合网站| 午夜欧美视频在线观看| 中文字幕欧美一区| 精品国产乱码久久久久久免费| 欧美午夜精品一区| 波多野结衣一区二区三区 | 欧美一区二区在线播放| 一本一道久久a久久精品| 国产精品888| 精品无码三级在线观看视频| 亚洲成人午夜电影| 一区二区三区四区亚洲| 国产精品久久久久久久岛一牛影视 | 国产精品亚洲人在线观看| 五月天国产精品| 亚洲永久免费av| 中日韩免费视频中文字幕| www久久精品| 精品盗摄一区二区三区| 91精品国产一区二区三区蜜臀| 91成人在线观看喷潮| 91麻豆产精品久久久久久| 国产成人av资源| 激情综合网天天干| 国产综合色视频| 黄色日韩网站视频| 精品一区二区三区免费播放 | 91麻豆产精品久久久久久| 福利一区福利二区| 国产一区欧美二区| 国产一区免费电影| 国产很黄免费观看久久| 国产中文字幕一区| 精品系列免费在线观看| 韩国精品主播一区二区在线观看 | 在线日韩一区二区| 色94色欧美sute亚洲线路二| 97精品国产97久久久久久久久久久久| 成人性色生活片| 99re热这里只有精品视频| 91麻豆国产精品久久| 在线一区二区视频| 欧美美女直播网站| 欧美电影免费观看高清完整版在 | 成人精品小蝌蚪| 99精品国产热久久91蜜凸| 91免费看片在线观看| 欧美中文字幕一区二区三区| 欧美丰满一区二区免费视频 | 亚洲精品国产a| 亚洲风情在线资源站| 日本亚洲视频在线| 国产毛片精品视频| 成人黄页在线观看| 欧美性猛交xxxx乱大交退制版| 欧美日韩性生活| 日韩免费观看高清完整版在线观看| 久久久精品综合| 亚洲视频电影在线| 丝瓜av网站精品一区二区| 精品亚洲国内自在自线福利| 成人午夜视频在线| 欧美亚洲日本一区| 精品国精品国产| 18欧美亚洲精品| 日本欧美一区二区| 成人午夜激情在线| 欧美妇女性影城| 久久精品水蜜桃av综合天堂| 亚洲特级片在线| 日本不卡视频在线观看| 成人一区二区三区视频| 欧美理论在线播放| 中国av一区二区三区| 亚洲成va人在线观看| 国产一区二区伦理片| 91精品91久久久中77777| 欧美va亚洲va国产综合| 亚洲欧洲精品一区二区三区不卡| 天天色 色综合| 成人黄页毛片网站| 日韩欧美色电影| 一区二区在线观看av| 激情综合色丁香一区二区| 91日韩精品一区| 精品国产伦一区二区三区免费 | 婷婷成人综合网| 国产91精品久久久久久久网曝门| 欧美日韩精品一区二区天天拍小说 | 成人av中文字幕| 91精品中文字幕一区二区三区| 国产精品免费av| 久久电影网站中文字幕| 欧美午夜精品久久久久久超碰 | 丁香啪啪综合成人亚洲小说| 欧美日韩视频第一区| 自拍偷拍欧美精品| 国产福利精品导航| 日韩视频一区二区三区在线播放| 1区2区3区精品视频| 国产精品自拍av| 日韩一区二区精品| 亚洲成av人**亚洲成av**| 97精品电影院| 中文字幕在线不卡| 国产麻豆9l精品三级站| 日韩欧美一区二区久久婷婷| 亚洲永久精品大片| 色综合天天综合| 国产精品久久久久aaaa| 国产一区二区伦理| 欧美精品一区二区三区很污很色的 | 国产精品久久久久影院| 韩日欧美一区二区三区| 日韩午夜精品视频| 日韩和欧美一区二区| 欧美日韩一区在线| 亚洲制服丝袜av| 在线免费不卡视频| 亚洲精品久久嫩草网站秘色| aa级大片欧美| 亚洲丝袜自拍清纯另类| av中文一区二区三区| 国产精品久久久久影院| 成人免费黄色在线| 国产精品的网站| 97精品国产97久久久久久久久久久久| 国产精品视频一二| eeuss影院一区二区三区| 中文字幕永久在线不卡| 91免费看视频| 亚洲国产综合人成综合网站| 欧美日韩三级在线| 日韩精品国产欧美| 日韩欧美电影一区| 国产一区二区毛片| 国产精品私人自拍| 91首页免费视频| 一区二区三区毛片| 欧美肥妇毛茸茸| 免费观看久久久4p| 久久香蕉国产线看观看99| 国产成人av网站| 亚洲人成影院在线观看| 在线一区二区视频| 免费在线观看视频一区| 欧美精品一区二区三区久久久| 国产成人免费在线视频| 中文字幕五月欧美| 欧美日韩国产免费一区二区 | 99久久婷婷国产综合精品电影| 亚洲色图欧美偷拍| 欧美日韩大陆一区二区| 精品制服美女丁香| 亚洲欧美中日韩| 欧美日韩免费电影| 国产在线观看一区二区| 国产精品久久久久久福利一牛影视| 在线免费观看日本一区| 麻豆成人91精品二区三区| 欧美国产一区在线| 91福利资源站| 国产一区久久久| 一二三区精品视频| 精品国精品自拍自在线| 色悠悠亚洲一区二区| 奇米在线7777在线精品| 欧美国产成人在线| 欧美精选午夜久久久乱码6080| 国产在线一区二区综合免费视频| 亚洲人成影院在线观看| 欧美电影免费观看高清完整版在线 | 色av成人天堂桃色av| 久久精品国产久精国产| 国产精品国产三级国产普通话三级 | 性欧美大战久久久久久久久| 国产午夜一区二区三区| 欧美亚洲禁片免费| 国产99一区视频免费| 亚洲成人免费视频| 国产婷婷色一区二区三区四区| 欧美亚洲一区二区在线| 国产电影一区二区三区| 天天做天天摸天天爽国产一区| 国产欧美日韩激情| 在线综合视频播放| 色综合久久天天| 国产成人日日夜夜| 麻豆精品蜜桃视频网站| 亚洲综合激情网| 国产精品久久免费看|