![]() |
AW: wie art der daten in blob erkennen?
meinte nicht dich ... war auf die Entwickler bei Emba bezogen, weil die zwanghaft immer jeden Dreck verstecken müssen und sich regelrecht weigern etwas öffentlich zugänglich zu machen. :wall:
|
AW: wie art der daten in blob erkennen?
Zitat:
UNGETESTET: Zitat:
Delphi-Quellcode:
function GetBytesFormat(const AData: TBytes): Integer;
begin Result := -1; if Length(AData) < 8 then Exit; case AData[0] of $FF: if CompareMem(@AData[0], @[$FF, $D8, $FF], 3) then Result := 0; // JPEG $89: if CompareMem(@AData[0], @[$89, $50, $4E, $47, $0D, $0A, $1A, $0A], 8) then Result := 1; // PNG $47: if CompareMem(@AData[0], @[$47, $49, $46, $38], 4) then Result := 2; // GIF $42: if CompareMem(@AData[0], @[$42, $4D], 2) then Result := 3; // BMP $00: if CompareMem(@AData[0], @[$00, $00, $01, $00], 4) then Result := 4; // ICO $49, $4D: if CompareMem(@AData[0], @[$49, $49, $2A, $00], 4) or CompareMem(@AData[0], @[$4D, $4D, $00, $2A], 4) then Result := 5; // TIF/TIFF end; end; Zitat:
|
AW: wie art der daten in blob erkennen?
Zitat:
|
AW: wie art der daten in blob erkennen?
Zitat:
Delphi-Quellcode:
Lesbarer wird es jedenfalls, wenn man Daten und Code noch etwas trennt.
{$SCOPEDENUMS ON}
type TImageFormat = (Unknown, BMP, GIF87a, TIFF, JPEG, PNG, ICO); {$POINTERMATH ON} function GetBytesFormat(const AData: TBytes): TImageFormat; var Signature: LongWord; begin Result := TImageFormat.Unknown; if Length(AData) >= 2 then if PWord(AData)^ = $4D42 then Result := TImageFormat.BMP; if Length(AData) >= 4 then case PLongWord(AData)^ of $DBFFD8FF, $01004649, $EEFFD8FF, $00006669, $E0FFD8FF: Result := TImageFormat.JPEG; $E0FFD8FF: if (Length(AData) >= 8) and ((PLongWord(AData) + 1)^ = $464A1000) then Result := TImageFormat.JPEG; $E1FFD8FF: if (Length(AData) >= 6) and ((PWord(AData) + 2)^ = $7845) then Result := TImageFormat.JPEG; $474E5089: if (Length(AData) >= 8) and ((PLongWord(AData) + 1)^ = $0A1A0A0D) then Result := TImageFormat.PNG; $38464947: if Length(AData) >= 6 then case (PWord(AData) + 2)^ of $6137, $6139: Result := TImageFormat.GIF87a; end; $00010000: Result := TImageFormat.ICO; $002A4949, $2A004D4D: Result := TImageFormat.TIFF; end; end;
Code:
type
{$SCOPEDENUMS ON} TImageFormat = (Unknown, BMP, GIF87a, TIFF, JPEG, PNG, ICO); {$SCOPEDENUMS OFF} TImageSignature = array[-2..7] of Byte; const cImageSignatures: array[0..13] of TImageSignature = ( (Ord(TImageFormat.JPEG), 4, $FF, $D8, $FF, $DB, 0, 0, 0, 0), (Ord(TImageFormat.JPEG), 8, $FF, $D8, $FF, $E0, $00, $10, $4A, $46), (Ord(TImageFormat.JPEG), 4, $49, $46, $00, $01, 0, 0, 0, 0), (Ord(TImageFormat.JPEG), 4, $FF, $D8, $FF, $EE, 0, 0, 0, 0), (Ord(TImageFormat.JPEG), 6, $FF, $D8, $FF, $E1, $45, $78, 0, 0), (Ord(TImageFormat.JPEG), 4, $69, $66, $00, $00, 0, 0, 0, 0), (Ord(TImageFormat.JPEG), 4, $FF, $D8, $FF, $E0, 0, 0, 0, 0), (Ord(TImageFormat.PNG), 8, $89, $50, $4E, $47, $0D, $0A, $1A, $0A), (Ord(TImageFormat.GIF87a), 6, $47, $49, $46, $38, $37, $61, 0, 0), (Ord(TImageFormat.GIF87a), 6, $47, $49, $46, $38, $39, $61, 0, 0), (Ord(TImageFormat.BMP), 2, $42, $4D, 0, 0, 0, 0, 0, 0), (Ord(TImageFormat.ICO), 4, $00, $00, $01, $00, 0, 0, 0, 0), (Ord(TImageFormat.TIFF), 4, $49, $49, $2A, $00, 0, 0, 0, 0), (Ord(TImageFormat.TIFF), 4, $4D, $4D, $00, $2A, 0, 0, 0, 0) ); function GetBytesFormat(const Data: TBytes): TImageFormat; begin for var Signature: TImageSignature in cImageSignatures do if (Length(Data) >= Signature[-1]) and CompareMem(@Data[0], @Signature[0], Signature[-1]) then Exit(TImageFormat(Signature[-2])); Result := TImageFormat.Unknown; end;
Delphi-Quellcode:
{$SCOPEDENUMS ON}
type TImageFormat = (Unknown, BMP, GIF87a, TIFF, JPEG, PNG, ICO); {$SCOPEDENUMS OFF} var cImageSignatures: array of array of Byte = [ [Ord(TImageFormat.JPEG), $FF, $D8, $FF, $DB], [Ord(TImageFormat.JPEG), $FF, $D8, $FF, $E0, $00, $10, $4A, $46], [Ord(TImageFormat.JPEG), $49, $46, $00, $01], [Ord(TImageFormat.JPEG), $FF, $D8, $FF, $EE], [Ord(TImageFormat.JPEG), $FF, $D8, $FF, $E1, $45, $78], [Ord(TImageFormat.JPEG), $69, $66, $00, $00], [Ord(TImageFormat.JPEG), $FF, $D8, $FF, $E0], [Ord(TImageFormat.PNG), $89, $50, $4E, $47, $0D, $0A, $1A, $0A], [Ord(TImageFormat.GIF87a), $47, $49, $46, $38, $37, $61], [Ord(TImageFormat.GIF87a), $47, $49, $46, $38, $39, $61], [Ord(TImageFormat.BMP), $42, $4D], [Ord(TImageFormat.ICO), $00, $00, $01, $00], [Ord(TImageFormat.TIFF), $49, $49, $2A, $00], [Ord(TImageFormat.TIFF), $4D, $4D, $00, $2A] ]; function GetBytesFormat(const Data: TBytes): TImageFormat; begin for var Signature in cImageSignatures do if (Length(Data) >= Length(Signature)-1) and CompareMem(@Data[0], @Signature[1], Length(Signature)-1) then Exit(TImageFormat(Signature[0])); Result := TImageFormat.Unknown; end; |
AW: wie art der daten in blob erkennen?
Zitat:
@himitsu: Cooler Ansatz, das muss ich dringend mal testen wie das bei den verschieden langen Signaturen aufgefüllt mit Nullen klappt.
Delphi-Quellcode:
Das muss ich erstmal verdauen das da ein negativer Startindex steht.
TImageSignature = array[-2..7] of Byte;
Delphi-Quellcode:
und wie sowas funktionieren soll mit den Nullen die nicht zur Signatur gehören.
(Ord(TImageFormat.BMP), 2, $42, $4D, 0, 0, 0, 0, 0, 0),
Delphi-Quellcode:
if CompareMem(@signature[0], @[$FF, $D8, $FF, $E1], 4) and CompareMem(@signature[6], @[$45, $78], 2) then
Result := 0 // JPEG
Delphi-Quellcode:
hier kann ich schonmal sagen ist ein Fehler unterlaufen, der zweite Teil fängt bei Offset 6 an, wo da Nullen stehen.
(Ord(TImageFormat.JPEG), 6, $FF, $D8, $FF, $E1, $45, $78, 0, 0),
Danke auf jeden Fall für die Verschönerung meines PoC! |
AW: wie art der daten in blob erkennen?
Ja, damit die Signatur bei [0] beginnt :lol:
bei [-1] die eigentliche Länge (ohne die Nullen) und auf [-2] das Format (hab mir ersparrt das mit einem Record-Array zu bauen (
Delphi-Quellcode:
)
array of record Format: TImageFormat; Len: Integer; Signature: array[0..7] of Byte; end;
Vor allem, da Record-Konstanten sinnlos pervers hässlich sind. Aber ginge auch mit
Delphi-Quellcode:
, also [0] das Format, [1] die Länge und ab [2] die Signatur.
array[0..9]
Bei einem statischen Array ist die zweite Ebene immer gleich groß, darum mußte aufgefüllt werden, aber nachfolgend, mit dynamischen Arrays, geht es ohne Füllbytes. |
AW: wie art der daten in blob erkennen?
Zitat:
Offset 6 ... falsch gelesen. also eigentlich
Delphi-Quellcode:
(Ord(TImageFormat.JPEG), 8, $FF, $D8, $FF, $E1, 0, 0, $45, $78)
joar dann muß man das Ganze noch um eine Maske (AND) erweitern, um die zwischenliegenden FüllBytes "ignorieren" zu können
Delphi-Quellcode:
(Ord(TImageFormat.JPEG), {Len} 8, {Daten} $FF, $D8, $FF, $E1, 0, 0, $45, $78, {Maske} $FF, $FF, $FF, $FF, 0, 0, $FF, $FF)
oder um eine zweite Prüfung (CompareMem) mit zusätzlichem Offset+Len.
Delphi-Quellcode:
(Ord(TImageFormat.JPEG), {Len1} 4, {Offest2} 6, {Len2} 2, {Daten1} $FF, $D8, $FF, $E1, 0, 0, {Daten2} $45, $78) // für Daten an gleicher Stelle (0..3 und 6..7)
Delphi-Quellcode:
(Ord(TImageFormat.JPEG), {Len1} 4, {Offest2} 6, {Len2} 2, {Daten1} $FF, $D8, $FF, $E1, {Daten2} $45, $78, 0, 0) // oder für Daten hintereinander (4+2 von 8)
und die Anderen alle mit
Delphi-Quellcode:
, also Offest2=0 für "gibt's nicht"
{Offest2} 0, {Len2} 0,
Die Maske hätte den Vorteil auch Bits ignorieren zu können, bzw. mehr als nur einen Sprung machen zu können. |
AW: wie art der daten in blob erkennen?
Zitat:
Sorry, mir gings ja nur drum, dass ChatGPT durchaus interessante Lösungs-Gerüste aus dem bestehenden Code anbietet. Ich habe ihm nicht gesagt, dass er die ersten Zeichen in ein case packen soll, das finde ich durchaus einen bemerkenswerten Schritt. Persönlich wäre ich auch eher in die Richtung von himitsu, von einer Array-Konstante ausgegangen, um die Formate schön übersichtlich und lesbar zu kapseln. Wenn ich das dem Bot noch mitteile, dann macht der das sicher auch noch in einem nächsten Step. Leider "optimiert" der auch immer was weg, das stimmt, aber er kann interessante Lösungsansätze bieten und zum Beispiel Lösungen auch von anderen Programmiersprachen in Delphi übertragen und kombinieren. Das finde ich sehr interessant, auch wenn der Code meistens nicht direkt lauffähig ist. </OT> Am Ende des Tages ist die gewünschte Lösung doch immer noch eine rein persönliche Geschmackssache. Deswegen finde ich alle Lösungsansätze auch OK, solange sie ihren Dienst tun, auch wenn ich da meine eigenen Favoriten habe. |
AW: wie art der daten in blob erkennen?
Moin in die runde.
also erstemal fettes TKS fuer die rege beteiligung, aber da ich nicht weiss, welche art daten in den blobs sein werden (und ich somit auch keinen einfluss darauf habe, ob das format vllt. mitgespeichert wurde), habe ich mir ueberlegt, das jetzt erstmal anders zu loesen, denn der "user" wird selbst am besten wissen, welche daten er in welchen blobs ablegt. daher mache ich einfach eine "konfigurierbare speichern-unter-funktion", wo er selbst auswaehlen kann, in welchem format er die datei speichern - oder fuer eine eventuelle preview temp. speichern will. und vllt. kann man ja sogar dabei festlegen, mit welchem "viewer" man(n)/frau/sonstiges diese betrachten will. und sollte jemand doch noch ne bessere idee haben - immer her damit. wuensche ein gesegnetes wochenende... ...de Schorsch |
AW: wie art der daten in blob erkennen?
So ist's richtig: Betroffene zu Beteiligten machen :-D
|
Alle Zeitangaben in WEZ +1. Es ist jetzt 06:09 Uhr. |
Powered by vBulletin® Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024-2025 by Thomas Breitkreuz