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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? idhashmessagedigest.pas

?? delphi indy9.0.18組件包
?? PAS
?? 第 1 頁 / 共 2 頁
字號:
{ $HDR$}
{**********************************************************************}
{ Unit archived using Team Coherence                                   }
{ Team Coherence is Copyright 2002 by Quality Software Components      }
{                                                                      }
{ For further information / comments, visit our WEB site at            }
{ http://www.TeamCoherence.com                                         }
{**********************************************************************}
{}
{ $Log:  10183: IdHashMessageDigest.pas 
{
{   Rev 1.0    2002.11.12 10:40:22 PM  czhower
}
{

  Implementation of the MD2, MD4 and MD5 Message-Digest Algorithm
  as specified in RFC 1319 (1115), 1320 (1186), 1321
 (See NOTE below for details of what is exactly implemented)

  Author: Pete Mee
  Port to Indy 8.1 Doychin Bondzhev (doychin@dsoft-bg.com)
  Copyright: (c) Chad Z. Hower and The Winshoes Working Group.

  NOTE:
  All MDx are ready and bug free.
}

unit IdHashMessageDigest;

{
2002-Feb-07 Pete Me
 - Fixed MD4 and MD5 for cases where n mod 512 = 448 where n is the number of
    bits processed.  An extra zero byte was being added to the input which
    offset the bit-size entry. 
2001-Oct-24 Pete Mee
 - Fixed MD4 and MD5 for cases where n mod 512 >= 448 where n is the number of
    bits processed.  This situation requires an additional block to be
    processed.
}

interface

uses
  Classes,
  IdGlobal,
  IdHash;

type
  T16x4LongWordRecord = array[0..15] of LongWord;
  T4x4x4LongWordRecord = array[0..3] of T4x4LongWordRecord;

  T384BitRecord = array [0..47] of byte;
  T128BitRecord = array [0..15] of byte;


  TIdHashMessageDigest = class(TIdHash128);

  TIdHashMessageDigest2 = class(TIdHashMessageDigest)
  protected
    FX: T384BitRecord;
    FCBuffer: T128BitRecord;
    FCheckSum: T128BitRecord;

    procedure MDCoder;
    procedure Reset;
  public
    function HashValue(AStream: TStream): T4x4LongWordRecord; override;
  end;

  TIdHashMessageDigest4 = class(TIdHashMessageDigest)
  protected
    FBuffer: T4x4LongWordRecord;
    FCBuffer: T16x4LongWordRecord;

    procedure MDCoder; virtual;

    function func_f(x, y, z : LongWord) : LongWord; virtual;
    function func_g(x, y, z : LongWord) : LongWord; virtual;
    function func_h(x, y, z : LongWord) : LongWord; virtual;
  public
    function HashValue(AStream: TStream): T4x4LongWordRecord; override;
  end;

  TIdHashMessageDigest5 = class(TIdHashMessageDigest4)
  protected
    procedure MDCoder; override;

    function func_g(x, y, z : LongWord) : LongWord; override;
    function func_i(x, y, z : LongWord) : LongWord; virtual;
  public

  end;

implementation

{ TIdHashMessageDigest2 }

const
  MD2_PI_SUBST : array [0..255] of byte = (
     41,  46,  67, 201, 162, 216, 124,   1,  61,  54,  84, 161, 236, 240,
      6,  19,  98, 167,   5, 243, 192, 199, 115, 140, 152, 147,  43, 217,
    188,  76, 130, 202,  30, 155,  87,  60, 253, 212, 224,  22, 103,  66,
    111,  24, 138,  23, 229,  18, 190,  78, 196, 214, 218, 158, 222,  73,
    160, 251, 245, 142, 187,  47, 238, 122, 169, 104, 121, 145,  21, 178,
      7,  63, 148, 194,  16, 137,  11,  34,  95,  33, 128, 127,  93, 154,
     90, 144,  50,  39,  53,  62, 204, 231, 191, 247, 151,   3, 255,  25,
     48, 179, 72, 165,  181, 209, 215,  94, 146,  42, 172,  86, 170, 198,
     79, 184,  56, 210, 150, 164, 125, 182, 118, 252, 107, 226, 156, 116,
      4, 241,  69, 157, 112,  89, 100, 113, 135,  32, 134,  91, 207, 101,
    230,  45, 168,   2,  27,  96,  37, 173, 174, 176, 185, 246,  28,  70,
     97, 105,  52,  64, 126, 15,   85,  71, 163,  35, 221,  81, 175,  58,
    195,  92, 249, 206, 186, 197, 234,  38,  44,  83,  13, 110, 133,  40,
    132,   9, 211, 223, 205, 244, 65,  129,  77,  82, 106, 220,  55, 200,
    108, 193, 171, 250,  36, 225, 123,   8,  12, 189, 177,  74, 120, 136,
    149, 139, 227,  99, 232, 109, 233, 203, 213, 254,  59,   0,  29,  57,
    242, 239, 183,  14, 102,  88, 208, 228, 166, 119, 114, 248, 235, 117,
     75,  10,  49,  68,  80, 180, 143, 237,  31,  26, 219, 153, 141,  51,
     159,  17, 131, 20);

procedure TIdHashMessageDigest2.MDCoder;
const
  NumRounds = 18;
Var
  i, j: Byte;
  T: Word;
  LCheckSumScore: Byte;
begin
  // Move the next 16 bytes into the second 16 bytes of X.
  Move(FCBuffer[0], FX[16], 16);
  for i := 0 to 15 do
  begin
    FX[i + 32] := FCBuffer[i] xor FX[i];
  end;

  { Do 18 rounds. }
  T := 0;
  for i := 0 to NumRounds - 1 do
  begin
    for j := 0 to 47 do
    begin
      T := FX[j] xor MD2_PI_SUBST[T];
      FX[j] := T and $FF;
    end;
    T := (T + i) and $FF;
  end;

  LCheckSumScore := FChecksum[15];
  for i := 0 to 15 do
  begin
    LCheckSumScore := FChecksum[i] xor MD2_PI_SUBST[FCBuffer[i]
      xor LCheckSumScore];
    FChecksum[i] := LCheckSumScore;
  end;
end;

// Clear Buffer and Checksum arrays
procedure TIdHashMessageDigest2.Reset;
begin
  FillChar(FCheckSum[0], 16, 0);
  FillChar(FCBuffer, 16, 0);
  // Initialise the X buffer to zero.
  FillChar(FX[0], 48, 0);
end;

function TIdHashMessageDigest2.HashValue(AStream: TStream): T4x4LongWordRecord;
Var
  LStartPos: Integer;
  LSize: Int64;
  S1: String;
begin
  Reset;

  LStartPos := AStream.Position;
  LSize := AStream.Size - LStartPos;

  // Code the entire file in complete 16-byte chunks.
  while LSize - AStream.Position >= SizeOf(FCBuffer) do
  begin
    AStream.Read(FCBuffer[0], SizeOf(FCBuffer));
    MDCoder;
  end;

  SetLength(S1, SizeOf(FCBuffer));

  LStartPos := AStream.Read(S1[1], 16);
  // Step 1
  FillChar(S1[LStartPos + 1], 16 - LStartPos, Byte(16 - LStartPos));
  Move(S1[1], FCBuffer[0], 16);
  MDCoder;
  // Step 2
  Move(FCheckSUm[0], FCBuffer[0], 16);
  MDCoder;

  Move(FX[0], result[0], 16);
end;

{ TIdHashMessageDigest4 }

const
  MD4_INIT_VALUES: T4x4LongWordRecord = (
    $67452301, $EFCDAB89, $98BADCFE, $10325476);

procedure TIdHashMessageDigest4.MDCoder;
var
  A, B, C, D, i : LongWord;
  I64 : Int64;
  buff : T4x4x4LongWordRecord; // 64-byte buffer

  function DoAdd(const AOne, ATwo, AThree, AFour : LongWord) : LongWord;
  begin
    I64 := AOne;
    I64 := ((I64 + ATwo) and $FFFFFFFF);
    I64 := ((I64 + AThree) and $FFFFFFFF) + AFour;
    result := I64 and $FFFFFFFF;
  end;
  
begin
  A := FBuffer[0];
  B := FBuffer[1];
  C := FBuffer[2];
  D := FBuffer[3];

  System.Move(FCBuffer[0], buff[0], SizeOf(buff));

  // The following additions utilise Int64 to avoid integer overflow

  // Round 1
  for i := 0 to 3 do
  begin 
    A := ROL(DoAdd(func_f(B, C, D), A, buff[i,0], 0), 3);
    D := ROL(DoAdd(func_f(A, B, C), D, buff[i,1], 0), 7);
    C := ROL(DoAdd(func_f(D, A, B), C, buff[i,2], 0), 11);
    B := ROL(DoAdd(func_f(C, D, A), B, buff[i,3], 0), 19);
  end;

  // Round 2
  for i := 0 to 3 do
  begin
    A := ROL(DoAdd(func_g(B, C, D), A, buff[0,i], $5A827999), 3);
    D := ROL(DoAdd(func_g(A, B, C), D, buff[1,i], $5A827999), 5);
    C := ROL(DoAdd(func_g(D, A, B), C, buff[2,i], $5A827999), 9);
    B := ROL(DoAdd(func_g(C, D, A), B, buff[3,i], $5A827999), 13);
  end;

  // Round 3
  A := ROL(DoAdd(func_h(B, C, D), A, T16x4LongWordRecord(buff)[0], $6ED9EBA1), 3);
  D := ROL(DoAdd(func_h(A, B, C), D, T16x4LongWordRecord(buff)[8], $6ED9EBA1), 9);
  C := ROL(DoAdd(func_h(D, A, B), C, T16x4LongWordRecord(buff)[4], $6ED9EBA1), 11);
  B := ROL(DoAdd(func_h(C, D, A), B, T16x4LongWordRecord(buff)[12], $6ED9EBA1), 15);
  A := ROL(DoAdd(func_h(B, C, D), A, T16x4LongWordRecord(buff)[2], $6ED9EBA1), 3);
  D := ROL(DoAdd(func_h(A, B, C), D, T16x4LongWordRecord(buff)[10], $6ED9EBA1), 9);

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲另类在线制服丝袜| 国产风韵犹存在线视精品| 日韩av电影免费观看高清完整版 | 国产欧美视频在线观看| 亚洲国产精品久久人人爱蜜臀 | 六月丁香婷婷久久| 91成人在线精品| 久久综合九色综合97婷婷| 午夜激情综合网| 97国产精品videossex| 欧美不卡一二三| 洋洋av久久久久久久一区| 国产69精品久久99不卡| 欧美不卡一区二区| 免费日韩伦理电影| 欧美无人高清视频在线观看| 国产精品色哟哟网站| 麻豆精品一区二区综合av| 欧美日韩的一区二区| 亚洲精品大片www| 99re亚洲国产精品| 中文字幕不卡在线观看| 国产在线视频一区二区| 欧美高清你懂得| 午夜久久久久久久久久一区二区| 色系网站成人免费| 亚洲影院免费观看| 欧美性感一区二区三区| 亚洲精品欧美专区| 日本高清免费不卡视频| 国产精品国产馆在线真实露脸| 国产jizzjizz一区二区| 日本一区二区三区国色天香| 国产精品99久久久久久有的能看| 久久久亚洲欧洲日产国码αv| 国产在线精品一区二区不卡了| 日韩西西人体444www| 久久99国产精品久久99果冻传媒| 日韩欧美的一区| 国产一区二区在线免费观看| 久久这里都是精品| 不卡影院免费观看| 亚洲猫色日本管| 欧美精品一级二级| 九色综合狠狠综合久久| 久久久综合视频| 波多野结衣的一区二区三区| 一区二区三区在线视频观看58| 欧美猛男男办公室激情| 久久成人av少妇免费| 国产精品视频yy9299一区| 色综合久久66| 奇米色一区二区| 国产日本亚洲高清| 色婷婷久久一区二区三区麻豆| 午夜私人影院久久久久| 精品久久久久99| 91亚洲资源网| 免费在线观看精品| 欧美国产日韩精品免费观看| 在线免费不卡电影| 伦理电影国产精品| 国产精品欧美久久久久无广告| 色婷婷综合久久| 日韩专区在线视频| 国产精品久久一级| 7777精品伊人久久久大香线蕉| 国产一区二区不卡在线| 亚洲免费资源在线播放| 8v天堂国产在线一区二区| 国产精品一级在线| 亚洲成人综合网站| 国产日韩av一区| 在线不卡免费欧美| av在线不卡网| 九色porny丨国产精品| 亚洲人亚洲人成电影网站色| 日韩三级免费观看| 在线一区二区观看| 粉嫩一区二区三区性色av| 亚洲成人黄色影院| 中文字幕制服丝袜一区二区三区| 日韩欧美一区在线| 在线免费不卡视频| 不卡高清视频专区| 国产在线精品一区二区夜色| 无码av免费一区二区三区试看 | 91亚洲精华国产精华精华液| 免费黄网站欧美| 亚洲精品国产a| 国产精品国产三级国产aⅴ原创| 日韩精品最新网址| 欧美二区乱c少妇| 91视频精品在这里| 国产成人精品一区二| 久久er精品视频| 美女诱惑一区二区| 午夜视频在线观看一区| 一区二区不卡在线播放 | 久久久久久久综合| 日韩一区二区三区视频| 欧美日韩亚洲国产综合| 91热门视频在线观看| 国产v日产∨综合v精品视频| 国产精品一卡二卡| 国产精品自拍毛片| 国产ts人妖一区二区| 国产成人一区在线| 国产二区国产一区在线观看| 国产激情偷乱视频一区二区三区| 喷水一区二区三区| 久久精品国产亚洲一区二区三区| 丝袜美腿亚洲色图| 婷婷开心激情综合| 亚洲成人第一页| 午夜精品福利在线| 亚洲123区在线观看| 午夜精品视频在线观看| 天堂一区二区在线免费观看| 天堂资源在线中文精品| 麻豆精品一区二区| 国产精选一区二区三区| 国产成人精品免费网站| 成人av电影观看| 色中色一区二区| 91精品一区二区三区久久久久久| 欧美一级在线观看| 26uuu国产在线精品一区二区| 精品久久人人做人人爽| 国产欧美一区二区三区沐欲| 国产精品国产三级国产有无不卡| 中文字幕亚洲区| 午夜精品福利视频网站| 精品一区二区三区视频| 成人中文字幕合集| 在线视频国内自拍亚洲视频| 宅男在线国产精品| 国产拍揄自揄精品视频麻豆| 亚洲精品中文字幕在线观看| 日韩极品在线观看| 国产精品一区二区久久精品爱涩| av色综合久久天堂av综合| 在线视频你懂得一区| 欧美v日韩v国产v| 中文文精品字幕一区二区| 一区二区久久久| 久久疯狂做爰流白浆xx| 91在线一区二区| 欧美成人国产一区二区| 国产精品高潮呻吟| 天堂久久久久va久久久久| 粉嫩高潮美女一区二区三区 | 欧美精品一区二区三区久久久| 日本一区二区三区在线不卡 | 国产精品123| 欧美三级日本三级少妇99| 欧美精品一区二区蜜臀亚洲| 国产精品福利一区二区三区| 日韩中文字幕91| 成人性生交大片免费看视频在线 | 精品欧美乱码久久久久久| 日本一区二区免费在线观看视频| 亚洲国产精品久久久男人的天堂| 国内精品自线一区二区三区视频| 欧美视频一区二区在线观看| 久久久久久久久久电影| 日韩极品在线观看| 色综合久久中文综合久久牛| 久久综合久久综合九色| 亚洲福利视频一区| 99视频有精品| 国产视频在线观看一区二区三区| 婷婷开心激情综合| 在线一区二区三区做爰视频网站| 亚洲国产电影在线观看| 激情综合亚洲精品| 欧美一区二区高清| 亚洲成人av资源| 欧洲中文字幕精品| 亚洲女人小视频在线观看| 国产精品一区二区男女羞羞无遮挡| 欧美精品久久99| 五月天视频一区| 欧美日韩精品欧美日韩精品| 自拍偷拍欧美激情| 成人精品gif动图一区| 久久精品一区蜜桃臀影院| 老司机精品视频在线| 日韩欧美中文一区二区| 天天影视涩香欲综合网| 欧美主播一区二区三区| 亚洲乱码中文字幕综合| 成人av网址在线| 国产精品人妖ts系列视频| 国产精品亚洲成人| 久久久午夜精品| 精品一区二区三区蜜桃| 欧美电视剧在线看免费| 免费成人在线网站| 日韩一级欧美一级|