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

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

?? labradmd5.pas

?? As science advances, novel experiments are becoming more and more complex, requiring a zoo of contro
?? PAS
字號:
{ Copyright (C) 2007 Markus Ansmann
 
  This program is free software: you can redistribute it and/or modify
  it under the terms of the GNU General Public License as published by
  the Free Software Foundation, either version 2 of the License, or
  (at your option) any later version.
 
  This program is distributed in the hope that it will be useful,
  but WITHOUT ANY WARRANTY; without even the implied warranty of
  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
  GNU General Public License for more details.
 
  You should have received a copy of the GNU General Public License
  along with this program.  If not, see <http://www.gnu.org/licenses/>.  }

{
 TODO:

}

unit LabRADMD5;

interface

  function MD5Digest(const s: string): string;

implementation

const
  k: array[0..63] of cardinal = ($D76AA478, $E8C7B756, $242070DB, $C1BDCEEE,
                                 $F57C0FAF, $4787C62A, $A8304613, $FD469501,
                                 $698098D8, $8B44F7AF, $FFFF5BB1, $895CD7BE,
                                 $6B901122, $FD987193, $A679438E, $49B40821,
                                 $F61E2562, $C040B340, $265E5A51, $E9B6C7AA,
                                 $D62F105D, $02441453, $D8A1E681, $E7D3FBC8,
                                 $21E1CDE6, $C33707D6, $F4D50D87, $455A14ED,
                                 $A9E3E905, $FCEFA3F8, $676F02D9, $8D2A4C8A,
                                 $FFFA3942, $8771F681, $6D9D6122, $FDE5380C,
                                 $A4BEEA44, $4BDECFA9, $F6BB4B60, $BEBFBC70,
                                 $289B7EC6, $EAA127FA, $D4EF3085, $04881D05,
                                 $D9D4D039, $E6DB99E5, $1FA27CF8, $C4AC5665,
                                 $F4292244, $432AFF97, $AB9423A7, $FC93A039,
                                 $655B59C3, $8F0CCC92, $FFEFF47D, $85845DD1,
                                 $6FA87E4F, $FE2CE6E0, $A3014314, $4E0811A1,
                                 $F7537E82, $BD3AF235, $2AD7D2BB, $EB86D391);
                                 
  r: array[0..63] of integer =  (7, 12, 17, 22, 7, 12, 17, 22, 7, 12, 17, 22, 7, 12, 17, 22,
                                 5,  9, 14, 20, 5,  9, 14, 20, 5,  9, 14, 20, 5,  9, 14, 20,
                                 4, 11, 16, 23, 4, 11, 16, 23, 4, 11, 16, 23, 4, 11, 16, 23,
                                 6, 10, 15, 21, 6, 10, 15, 21, 6, 10, 15, 21, 6, 10, 15, 21);

  o: array[0..63] of integer =  ( 4,  4,  4,  4,  4,  4,  4,  4,  4,  4,  4,  4,  4,  4,  4,-56,
                                 20, 20,-44, 20, 20, 20,-44, 20, 20,-44, 20, 20,-44, 20, 20,-28,
                                 12, 12, 12,-52, 12, 12, 12, 12,-52, 12, 12, 12, 12, 12,-52, -8,
                                 28, 28,-36, 28,-36, 28,-36, 28, 28,-36, 28,-36, 28,-36, 28, 28);

type
  TWord = record
            case boolean of
              True:  (AsBytes: packed array[0..3] of byte);
              False: (AsWord:  cardinal);
          end;

function MD5Digest(const s: string): string;
var h0, h1, h2, h3: cardinal;
    a, b, c, d:     cardinal;
    f, temp:        cardinal;
    i, ofs, len:    integer;
    w:              TWord;
begin
  // Initialize "state"
  h0 := $67452301;
  h1 := $EFCDAB89;
  h2 := $98BADCFE;
  h3 := $10325476;
  // Offset of length information
  len:=(length(s)+9+63) and $FFFFFFC0 - 7;
  // Current working offset
  ofs:=1;
  while ofs<len+8 do begin
    // Initialize hash value for chunk
    a:=h0;
    b:=h1;
    c:=h2;
    d:=h3;
    for i:=0 to 63 do begin
      // Apply correct round of operations
      case i of
        0..15: f:=d xor (b and (c xor d));
       16..31: f:=c xor (d and (b xor c));
       32..47: f:=b xor         c xor d;
       else    f:=c xor (b or    (not d));
      end;
      // Grab word out of string + pad + length
      if ofs+3<=length(s) then
        move(s[ofs], w.AsWord, 4)
       else if ofs=len then
        w.AsWord:=(cardinal(length(s)) and $1FFFFFFF) shl  3
       else if ofs=len+4 then
        w.AsWord:=         (length(s)  and $FFFFFFFF) shr 29
       else if ofs>length(s)+1 then
        w.AsWord:=0
       else begin
        w.AsWord:=0;
        move(s[ofs], w.AsWord, length(s)+1-ofs);
        w.AsBytes[length(s)+1-ofs]:=$80;
      end;
      // Rotate
      temp:=d;
      d:=c;
      c:=b;
      a:=(a + f + k[i] + w.AsWord) and $FFFFFFFF;
      b:=(b + (((a shl r[i]) and $FFFFFFFF) or (a shr (32-r[i])))) and $FFFFFFFF;
      a:=temp;
      ofs:=ofs+o[i];
    end;
    // Sum into state
    h0:=(h0+a) and $FFFFFFFF;
    h1:=(h1+b) and $FFFFFFFF;
    h2:=(h2+c) and $FFFFFFFF;
    h3:=(h3+d) and $FFFFFFFF;
  end;
  // Build digest
  setlength(Result, 16);
  move(h0, Result[ 1], 4);
  move(h1, Result[ 5], 4);
  move(h2, Result[ 9], 4);
  move(h3, Result[13], 4);
end;

end.

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲精品国产一区二区三区四区在线| 国产自产视频一区二区三区| 一区二区三区产品免费精品久久75| 亚洲一区二区三区免费视频| 韩国欧美国产1区| 欧洲人成人精品| 国产精品网站一区| 人人超碰91尤物精品国产| 94-欧美-setu| 国产三级精品三级在线专区| 日本视频一区二区三区| 91亚洲精品乱码久久久久久蜜桃| 欧美精品一区二区三区很污很色的 | 日韩欧美一区在线观看| 亚洲欧洲一区二区在线播放| 蜜桃av一区二区在线观看| 91成人免费在线| 国产精品美女久久久久久久网站| 另类欧美日韩国产在线| 欧美老肥妇做.爰bbww| 亚洲精品第一国产综合野| 国产激情一区二区三区桃花岛亚洲| 6080国产精品一区二区| 亚洲最大的成人av| 色欧美日韩亚洲| 中文字幕在线一区| 成人国产亚洲欧美成人综合网| 26uuu另类欧美亚洲曰本| 久久激情五月激情| 日韩免费观看高清完整版在线观看| 亚洲国产日韩综合久久精品| 91国偷自产一区二区三区成为亚洲经典| 国产网站一区二区三区| 国产精品综合视频| 国产欧美一二三区| 国产米奇在线777精品观看| 日韩免费观看高清完整版| 日韩精品一区第一页| 在线不卡a资源高清| 午夜久久久影院| 日韩视频一区在线观看| 奇米亚洲午夜久久精品| 精品区一区二区| 国产激情91久久精品导航| 亚洲国产精品传媒在线观看| 99久久精品一区| 一区二区三区日韩欧美| 欧美丝袜丝交足nylons图片| 亚洲电影激情视频网站| 欧美高清你懂得| 国内成人精品2018免费看| 亚洲国产成人在线| 日本道色综合久久| 蜜桃视频一区二区| 国产欧美一区二区在线观看| 91免费精品国自产拍在线不卡| 亚洲一二三区视频在线观看| 国产精品午夜在线| 91成人国产精品| 久久电影国产免费久久电影| 国产网站一区二区三区| 91国在线观看| 久久国产剧场电影| 一色桃子久久精品亚洲| 在线播放/欧美激情| 国产永久精品大片wwwapp| 亚洲欧洲日韩在线| 欧美疯狂做受xxxx富婆| 国产福利一区二区| 亚洲午夜久久久久久久久电影网| 日韩视频一区二区三区在线播放| 成人美女视频在线看| 亚洲电影在线免费观看| 久久综合久久综合久久综合| 色狠狠av一区二区三区| 国产又黄又大久久| 亚洲福利一二三区| 国产精品区一区二区三| 日韩一区二区三区在线| 99视频在线观看一区三区| 日产国产高清一区二区三区| 国产精品久久久久精k8| 日韩欧美一区二区三区在线| 99国产精品国产精品久久| 美女一区二区视频| 一区二区三区加勒比av| 国产亚洲一区二区在线观看| 欧美另类z0zxhd电影| voyeur盗摄精品| 精品一区二区三区不卡| 亚洲国产综合91精品麻豆| 中文字幕av资源一区| 欧美一区二区三区视频| 精品国产3级a| 欧美日韩精品一区二区天天拍小说 | 亚洲另类在线一区| 国产欧美日韩久久| 精品国产乱子伦一区| 5566中文字幕一区二区电影| 色丁香久综合在线久综合在线观看| 精品中文字幕一区二区| 日日欢夜夜爽一区| 亚洲男人电影天堂| 中文一区二区在线观看| 久久欧美中文字幕| 欧美videossexotv100| 欧美日韩高清一区| 91福利视频在线| 色综合婷婷久久| 91在线小视频| 91麻豆蜜桃一区二区三区| 成人黄色国产精品网站大全在线免费观看| 久久99精品一区二区三区三区| 亚洲丶国产丶欧美一区二区三区| 亚洲精品成人天堂一二三| 国产精品黄色在线观看| 国产精品盗摄一区二区三区| 中文字幕第一区第二区| 国产精品久久久久久一区二区三区| 国产日韩av一区| 日日噜噜夜夜狠狠视频欧美人| 一区二区在线观看不卡| 亚洲美女屁股眼交| 一片黄亚洲嫩模| 婷婷一区二区三区| 蜜桃精品视频在线观看| 麻豆精品在线看| 国产伦精品一区二区三区免费迷 | www一区二区| 亚洲精品一区二区三区福利| 久久久99免费| 国产精品天天看| 亚洲激情中文1区| 偷拍与自拍一区| 狠狠狠色丁香婷婷综合久久五月| 国产精品亚洲一区二区三区在线| 懂色av中文字幕一区二区三区| 波多野结衣在线一区| 色老汉av一区二区三区| 777午夜精品视频在线播放| 日韩欧美国产午夜精品| 中文字幕乱码日本亚洲一区二区| 亚洲欧美成aⅴ人在线观看| 亚洲va欧美va国产va天堂影院| 蜜桃av噜噜一区二区三区小说| 国产乱妇无码大片在线观看| 99久久精品国产导航| 欧美区在线观看| 国产亚洲一区字幕| 亚洲一区二区三区四区在线| 久久精品国产精品亚洲综合| 成人免费视频免费观看| 欧美三级电影精品| 久久久国产午夜精品| 亚洲一区二区三区视频在线| 久久97超碰色| 一本一道久久a久久精品综合蜜臀| 91精品国产aⅴ一区二区| 欧美高清一级片在线观看| 亚洲成av人片一区二区三区| 一本色道a无线码一区v| 欧美精选一区二区| 国产精品美女久久久久久2018 | 国产亚洲精品bt天堂精选| 一区二区三区在线视频免费观看| 免费成人小视频| 色婷婷国产精品| 久久亚洲综合色| 午夜精品福利在线| 成人福利视频在线| 26uuu国产一区二区三区| 亚洲国产va精品久久久不卡综合| 国产精品一区二区免费不卡| 欧美精品乱人伦久久久久久| 国产精品久久久一本精品| 精品一区二区三区蜜桃| 精品1区2区3区| 中文字幕综合网| 高清视频一区二区| 精品欧美久久久| 日产欧产美韩系列久久99| 在线精品视频免费观看| 中文字幕精品在线不卡| 精品一区二区三区视频 | 欧美一级生活片| 亚洲主播在线播放| 91麻豆福利精品推荐| 国产欧美日韩不卡免费| 狠狠色狠狠色综合| 日韩视频一区二区| 免费观看在线色综合| 欧美人动与zoxxxx乱| 亚洲免费在线观看视频| 91亚洲精品久久久蜜桃网站| 日本一区二区免费在线观看视频| 精品亚洲aⅴ乱码一区二区三区| 欧美一区二区三区免费视频 | 91社区在线播放| 专区另类欧美日韩| 一本久道久久综合中文字幕 |