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

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

?? idhashmessagedigest.pas

?? delphi indy9.0.18組件包
?? PAS
?? 第 1 頁(yè) / 共 2 頁(yè)
字號(hào):
{ $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);

?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
99视频热这里只有精品免费| 午夜国产不卡在线观看视频| 久久电影网站中文字幕| 91久久奴性调教| 久久午夜羞羞影院免费观看| 美日韩一区二区| 日韩欧美一区在线观看| 爽好多水快深点欧美视频| 欧美日韩午夜影院| 亚洲第一主播视频| 欧美二区在线观看| 蜜桃视频在线观看一区| 欧美一二三区在线观看| 伊人一区二区三区| 欧美视频一区二区在线观看| 亚洲国产成人高清精品| 7777精品伊人久久久大香线蕉完整版 | 欧美三级视频在线播放| 亚洲第一久久影院| 欧美肥妇毛茸茸| 美女性感视频久久| 久久久国产综合精品女国产盗摄| 国产成人在线视频播放| 国产精品国产三级国产专播品爱网| 成人一二三区视频| 综合分类小说区另类春色亚洲小说欧美| 麻豆成人久久精品二区三区红 | 欧美亚男人的天堂| 日韩国产欧美视频| 2020国产精品自拍| 成人99免费视频| 亚洲人成影院在线观看| 91麻豆福利精品推荐| 一区二区三区日韩在线观看| 91麻豆免费视频| 亚洲国产中文字幕| 欧美精品在线观看播放| 精一区二区三区| 精品99一区二区| 91蜜桃免费观看视频| 日韩国产欧美在线视频| 国产精品水嫩水嫩| 欧美日韩国产精选| 国产精品77777竹菊影视小说| 亚洲欧美日韩国产成人精品影院| 91精品国产乱码| 九九视频精品免费| 洋洋成人永久网站入口| 欧美视频你懂的| 午夜激情综合网| 国产精品三级久久久久三级| 7777精品伊人久久久大香线蕉经典版下载 | 欧美大肚乱孕交hd孕妇| 成人午夜电影久久影院| 亚洲sss视频在线视频| 日韩一级片网址| av资源网一区| 精品一区二区国语对白| 亚洲天堂2016| 国产亚洲综合在线| 欧美久久久影院| 色婷婷av一区二区三区之一色屋| 日韩极品在线观看| 综合久久久久久久| 久久精品亚洲麻豆av一区二区 | 三级亚洲高清视频| 日韩理论片网站| 欧美日韩一区二区三区不卡 | 欧美变态凌虐bdsm| 色哟哟一区二区| 99精品黄色片免费大全| 国产大陆亚洲精品国产| 国产精品一二三四五| 韩国一区二区三区| 日韩精品电影在线| 亚洲国产色一区| 一区二区三区在线播放| 国产精品毛片久久久久久| 久久婷婷综合激情| 在线观看免费一区| av动漫一区二区| 丁香婷婷综合五月| 国产一级精品在线| 久久草av在线| 亚洲国产综合在线| 亚洲综合色视频| 亚洲一区二区三区美女| 亚洲午夜精品网| 亚洲成人一区在线| 亚洲第一av色| 一二三区精品视频| 亚洲午夜精品在线| 亚洲成人黄色影院| 亚洲一区视频在线| 亚洲一区日韩精品中文字幕| 中文字幕一区二区在线观看| 久久久综合激的五月天| 精品国产一区二区三区久久久蜜月| 日韩一区二区在线观看视频| 欧美一级淫片007| 欧美日韩在线综合| 678五月天丁香亚洲综合网| 欧美午夜精品久久久| 欧美综合一区二区三区| 91麻豆精品91久久久久同性| 91精品国产综合久久久久久漫画 | 亚洲三级电影网站| 亚洲精品免费播放| 亚洲在线免费播放| 偷拍日韩校园综合在线| 久久99国产精品久久99果冻传媒 | 国产乱色国产精品免费视频| 国产主播一区二区| 国产91综合一区在线观看| av一本久道久久综合久久鬼色| 色综合色狠狠天天综合色| 欧美自拍偷拍一区| 欧美电影影音先锋| 久久一夜天堂av一区二区三区| 日韩一区二区电影网| 欧美国产一区二区| 亚洲美女屁股眼交3| 日韩综合在线视频| 激情欧美一区二区| 色婷婷久久久久swag精品| 精品福利二区三区| 亚洲综合久久久| 国产91精品欧美| 欧美福利电影网| 亚洲人快播电影网| 国产麻豆视频一区| 欧美喷潮久久久xxxxx| 国产精品国产三级国产aⅴ原创| 日韩成人dvd| 91丨九色丨黑人外教| 久久九九久精品国产免费直播| 性久久久久久久| 91网上在线视频| 欧美国产成人在线| 九九精品视频在线看| 欧美色大人视频| 亚洲免费观看高清完整版在线观看| 狠狠色狠狠色合久久伊人| 欧美在线你懂得| 国产精品超碰97尤物18| 国产精品一级黄| 精品国精品自拍自在线| 日本成人在线网站| 欧美视频精品在线观看| 亚洲精品国产无套在线观| 成人97人人超碰人人99| 国产日韩欧美精品一区| 激情综合网天天干| 欧美一级片在线看| 日日摸夜夜添夜夜添精品视频| 欧美综合一区二区| 一区二区三区在线观看视频| 91免费国产在线| 亚洲私人影院在线观看| 成人高清免费观看| 国产精品欧美经典| 成人免费视频caoporn| 久久久久久黄色| 国产专区欧美精品| 久久精品视频在线看| 国产精品自在在线| 久久久久久久久久久电影| 国产一区二区三区免费播放 | 国产亚洲福利社区一区| 国产真实精品久久二三区| 精品国产一区二区三区不卡 | 欧美一级专区免费大片| 麻豆一区二区在线| 亚洲精品一区二区在线观看| 国产资源在线一区| 国产精品欧美综合在线| 91污片在线观看| 一区二区三区不卡在线观看 | 中文字幕一区三区| 在线一区二区三区四区五区| 亚洲在线免费播放| 欧美裸体一区二区三区| 捆绑紧缚一区二区三区视频 | 中文字幕色av一区二区三区| 99re在线精品| 午夜欧美电影在线观看| 欧美一级高清片在线观看| 韩国av一区二区三区四区| 国产亚洲欧洲997久久综合| av在线这里只有精品| 亚洲午夜影视影院在线观看| 91精品久久久久久蜜臀| 国产麻豆视频一区二区| 亚洲少妇30p| 欧美丰满少妇xxxxx高潮对白| 国内精品伊人久久久久影院对白| 中文字幕一区二区三区精华液| 欧美色成人综合| 国产成人欧美日韩在线电影| 伊人一区二区三区|