Computerhilfen.de Logo
Forum
Tipps
News

Javaimplementierung des MD5 Algorithmus

Hallo,
ich versuche gerade die Hashfunktion MD5 in Java umzusetzen, bekomme es jedoch nicht ganz hin.
habe mir schon eine Pseudocode besorgt, den ich jetzt versuche in Java zu übersetzen.
Vielleicht hat ja jemand von euch das schon gemacht und kann mir behilflich sein oder sogar den Code posten.
Toll wäre auch eine leicht verständliche Erklärung zu jedem Schritt.
Besten Dank schonmal!
Hier meine bisherige Arbeit:


import java.math.*;
import java.util.*;
import java.lang.Number;
// Beachte: Alle Variablen sind vorzeichenlose 32 Bit-Werte und
// verhalten sich bei Berechnungen kongruent modulo 2^32

class MD5 {
 
  String zMessage;
   
public void ausführen(String pMessage){
 
    pMessage = zMessage;
   
 
  // Definiere r wie folgt:
   int[] r = {

         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
    };
 
  int[] t = {
    0xd76aa478, 0xe8c7b756, 0x242070db, 0xc1bdceee, 0xf57c0faf, 0x4787c62a,
    0xa8304613, 0xfd469501, 0x698098d8, 0x8b44f7af, 0xffff5bb1, 0x895cd7be,
    0x6b901122, 0xfd987193, 0xa679438e, 0x49b40821, 0xf61e2562, 0xc040b340,
    0x265e5a51, 0xe9b6c7aa, 0xd62f105d, 0x2441453, 0xd8a1e681, 0xe7d3fbc8,
    0x21e1cde6, 0xc33707d6, 0xf4d50d87, 0x455a14ed, 0xa9e3e905, 0xfcefa3f8,
    0x676f02d9, 0x8d2a4c8a, 0xfffa3942, 0x8771f681, 0x6d9d6122, 0xfde5380c,
    0xa4beea44, 0x4bdecfa9, 0xf6bb4b60, 0xbebfbc70, 0x289b7ec6, 0xeaa127fa,
    0xd4ef3085, 0x4881d05, 0xd9d4d039, 0xe6db99e5, 0x1fa27cf8, 0xc4ac5665,
    0xf4292244, 0x432aff97, 0xab9423a7, 0xfc93a039, 0x655b59c3, 0x8f0ccc92,
    0xffeff47d, 0x85845dd1, 0x6fa87e4f, 0xfe2ce6e0, 0xa3014314, 0x4e0811a1,
    0xf7537e82, 0xbd3af235, 0x2ad7d2bb, 0xeb86d391};
 
  // Initialisiere die Variablen:
   int h0 = 0x67452301;
   int h1 = 0xEFCDAB89;
   int h2 = 0x98BADCFE;
   int h3 = 0x10325476;

  // Verwende den binären Vorkommateil vom 2^32-fachen Betrag des Sinus
  // von Integerwerten als Konstanten:
      for( int i=0; i<=63; i++){
        t =(int)(Math.floor(Math.abs(Math.sin(i +1)) * 4294967296));
      }

 

  // Vorbereitung der Nachricht 'zMessage':
  byte [] text ={};
  text=zMessage.getBytes();
  Message msg = new Message(text);
  if(!text = 448 % 512)
  while (! text = 448 % 512){
    text +1;}
 
   
 

  // Verarbeite die Nachricht in aufeinander folgenden 512-Bit Blöcken:
  für alle 512-Bit Block von message
      unterteile Block in 16 32-bit little-endian Worte w(i), 0 ≤ i ≤ 15

      // Initialisiere den Hash-Wert für diesen Block:
      var int a = h0
      var int b = h1
      var int c = h2
      var int d = h3

      // Hauptschleife:
      für alle i von 0 bis 63
          wenn 0 ≤ i ≤ 15 dann
              f = (b and c) or ((not b) and d)
              g = i
          sonst wenn 16 ≤ i ≤ 31 dann
              f = (d and b) or ((not d) and c)
              g = (5×i + 1) mod 16
          sonst wenn 32 ≤ i ≤ 47 dann
              f = b xor c xor d
              g = (3×i + 5) mod 16
          sonst wenn 48 ≤ i ≤ 63 dann
         

        c xor (b or (not d))
              g := (7×i) mod 16
          wenn_ende
   
          temp = d
          d = c
          c = b
          b = ((a + f + k(i) + w(g)) leftrotate r(i)) + b
          a = temp

      // Addiere den Hash-Wert des Blocks zur Summe der vorherigen Hashes:
      h0 = h0 + a
      h1 = h1 + b
      h2 = h2 + c
      h3 = h3 + d

  var int digest = h0 append h1 append h2 append h3 //(Darstellung als little-endian)

}

}

// QUELLEN
//http://www.latenightlecture.de/fileadmin/vortrage/jonas/20051201/Md5.pdf
//http://de.wikipedia.org/wiki/Message-Digest_Algorithm_5
//Schild, Herbert & O'Neil "Java 2 GE-PACKT"
 


Antworten zu Javaimplementierung des MD5 Algorithmus:

Hat dir diese Antwort geholfen?

Danke ButtonHilfreiche Antwort Button

Legst du Wert auf die Implementierung? Wenn nicht, kannst du die MessageDigest-Klasse verwenden, die kann sowas nämlich schon:
http://java.sun.com/j2se/1.5.0/docs/api/java/security/MessageDigest.html

danke für die antwort, aber "leider" gehts mir um die implementierung! :=)


« Ich möchte einen Online 2D-Shooter programmieren!Java Script Fehler »
 

Schnelle Hilfe: Hier nach ähnlichen Fragen und passenden Tipps suchen!