AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Thema durchsuchen
Ansicht
Themen-Optionen

Expert Witness Compression

Ein Thema von Alter Mann · begonnen am 22. Aug 2010 · letzter Beitrag vom 5. Nov 2010
Antwort Antwort
Alter Mann

Registriert seit: 15. Nov 2003
Ort: Berlin
946 Beiträge
 
Delphi 10.2 Tokyo Professional
 
#1

Expert Witness Compression

  Alt 22. Aug 2010, 18:30
Hallo miteinander,
ich habe ein kleines Problem mit der EWF-Komprimierung, laut dieser Quelle enthält die gesamte Sektion Headerzlib“ komprimierte Daten. Versuche ich sie so zu öffnen (function GetHeaderSection(Buffer :TBytes): TEncaseHeaderSection;):
Delphi-Quellcode:
unit uEncase;

interface

uses
  Windows, SysUtils, Classes, Controls;

type
  TSectionType = (stHeader, stVolume, stDisk, stTable, stSection, stData, stError2, stHash, stNext, stDone);

  TEncaseHeader = packed record
    MagicBytes : Array[0..7] of Byte;
    ID : Byte; // Immer 0x01
    SegmentNumber : Word;
    ControlID : Word; // Immer 0x0000
  end;

  TEncaseSection = packed record
    SectionType : Array[0..15] of AnsiChar;
    Offset : Int64;
    Size : Int64;
    Reserved : Array[0..39] of Byte;
    CRCValue : DWORD;
  end;

  TEncaseHeaderSection = record
    Aktenzahl,
    BeweisID,
    Beschreibung,
    Ersteller,
    Notizen,
    ErstellDatum,
    SystemZeit,
    PwHash,
    Compression,
    EncaseVersion,
    OSVersion : String;
  end;

  TEncaseVolumeDiskSection = packed record
    Reserved : DWORD;
    ClusterCount : DWORD;
    SectorPerCluster: DWORD;
    BytesPerSector : DWORD;
    SectorCount : DWORD;
    Reserved1 : Array[0..19] of Byte;
    Fill : Array of Byte;
    CRCValue : DWORD;
  end;

  TEncaseTableSection = packed record
    Count : DWORD;
    Fill : Array[0..15] of Byte;
    CRCValue : DWORD;
    Offset : Array[Count * Word] of Byte;
    CRCValue2 : DWORD;
  end;

  TEncaseHashSection = packed record
    MD5Hash : Array[0..15] of Byte;
    CRCValue : DWORD;
  end;

function IsMagicEncase(MagicBytes : Array of Byte) : Boolean;
function GetSectionType(SectionType : Array of AnsiChar) : TSectionType;
function GetHeaderSection(Buffer : TBytes): TEncaseHeaderSection;

implementation

uses
   zLib;

function CRC(const sString: String; iPrevKey: DWord = 1): DWord;
var
  Buf: String;
  b, d: DWord;
  i: Integer;
begin
  Buf := sString;
  b := iPrevKey and $ffff;
  d := (iPrevKey shr 16) and $ffff;
  for i := 1 to Length(sString) do begin
    Inc(b, Ord(Buf[i]));
    Inc(d, b);
    if ( (i <> 0) and ( (i mod $15b0 = 0) or (i = Length(sString)) ) ) then begin
      b := b mod $fff1;
      d := d mod $fff1;
    end;
  end;
  Result := ((d shl 16) or b);
end;

function IsMagicEncase(MagicBytes : Array of Byte) : Boolean;
begin
  Result := false;
  if Length(MagicBytes) = 8 then
  begin
    Result := ((MagicBytes[0] = 69) and
               (MagicBytes[1] = 86) and
               (MagicBytes[2] = 70) and
               (MagicBytes[3] = 9) and
               (MagicBytes[4] = 13) and
               (MagicBytes[5] = 10) and
               (MagicBytes[6] = 255) and
               (MagicBytes[7] = 0));
  end;
end;

function GetSectionType(SectionType : Array of AnsiChar) : TSectionType;
begin
  if SectionType = 'header'   then Result := stHeader
  else
  if SectionType = 'volume'   then Result := stVolume
  else
  if SectionType = 'disk'     then Result := stDisk
  else
  if SectionType = 'table'    then Result := stTable
  else
  if SectionType = 'section'  then Result := stSection
  else
  if SectionType = 'data'     then Result := stData
  else
  if SectionType = 'error2'   then Result := stError2
  else
  if SectionType = 'hash'     then Result := stHash
  else
  if SectionType = 'next'     then Result := stNext
  else
  if SectionType = 'done'     then Result := stDone;
end;

function GetHeaderSection(Buffer :TBytes): TEncaseHeaderSection;
var
  MS : TMemoryStream;
  OS : TMemoryStream;
  DS : TZDecompressionStream;
  S : String;
begin
  MS := TMemoryStream.Create;
  try
    MS.Write(Buffer, Length(Buffer));
    MS.Position := 0;
    OS := TMemoryStream.Create;
    try
      DS := TZDecompressionStream.Create(MS);
      try
         DS.Position := 0;
         OS.CopyFrom(DS, DS.Size);
      finally
        DS.Free;
      end;
      OS.Write(S, SizeOf(String));
    finally
      OS.Free;
    end;
  finally
    MS.Free;
  end;
end;

end.
gibt es einen Crash.
Hat jemand eine Idee?

Danke
  Mit Zitat antworten Zitat
Benutzerbild von Assarbad
Assarbad

Registriert seit: 8. Okt 2010
Ort: Frankfurt am Main
1.234 Beiträge
 
#2

AW: Expert Witness Compression

  Alt 4. Nov 2010, 00:32
Haste ne Beispieldatei zum Testen?

Interessieren würde mich auch noch wo der Absturz passiert? Bei der Dekomprimierung direkt? Es gibt da nämlich zwei verschiedene Formate, die zwar miteinander zu tun haben, da der Algo der gleiche ist, aber deren Format ist leicht verschieden ist kann bei schlecht programmierter Inflate-Funktionalität bspw. einen Absturz hervorgerufen werden.

1. RFC 1951 - DEFLATE Compressed Data Format Specification version
2. RFC 1952 - GZIP file format specification version 4.3

Nachtrag: gerade das hier gefunden. Ziemlich schwach für einen Standard nicht exakt zu besagen welches Format es ist. Es klingt aber nach Deflate (also RFC 1951).
Oliver
"... aber vertrauen Sie uns, die Physik stimmt." (Prof. Harald Lesch)

Geändert von Assarbad ( 4. Nov 2010 um 00:41 Uhr)
  Mit Zitat antworten Zitat
idefix2

Registriert seit: 17. Mär 2010
Ort: Wien
1.027 Beiträge
 
RAD-Studio 2009 Pro
 
#3

AW: Expert Witness Compression

  Alt 5. Nov 2010, 09:17
Zitat:
gibt es einen Crash.
Das heisst? Welche Fehlermeldung, und an welcher Stelle genau im Programm?
  Mit Zitat antworten Zitat
Antwort Antwort


Forumregeln

Es ist dir nicht erlaubt, neue Themen zu verfassen.
Es ist dir nicht erlaubt, auf Beiträge zu antworten.
Es ist dir nicht erlaubt, Anhänge hochzuladen.
Es ist dir nicht erlaubt, deine Beiträge zu bearbeiten.

BB-Code ist an.
Smileys sind an.
[IMG] Code ist an.
HTML-Code ist aus.
Trackbacks are an
Pingbacks are an
Refbacks are aus

Gehe zu:

Impressum · AGB · Datenschutz · Nach oben
Alle Zeitangaben in WEZ +1. Es ist jetzt 16:49 Uhr.
Powered by vBulletin® Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz