Uncompressed Adobe's Flash XFL format still keeps a lot of content compressed. Does anybody know specification of these binary *.dat files?
2 Answers
The *.dat files stores various type of media content. What I can say so far is, that:
- images are stored as JPEGs without additional info. That means just renaming *.dat is enough to get the original image. Such a files starts with #{FFD8}
- images are stored in some internal RAW format. Using reverse engineering I can say that for example bitmap with raw pixel data #{FFFFFFFF} (1x1) is stored as:
0305 ;raw bitmap identifier? 0400 ;length of decompressed row data 0100 ;width 0100 ;height 00000000 ;unknown 14000000 ;width in twips 00000000 ;unknown 14000000 ;height in twips 00 ;some flags - 01=image has transparency variant 1.: 01 ;compressed data flag 0200 ;length of compressed chunk 7801 ;compressed chunk 0A00 ;length of compressed chunk FBFFFFFF7F0009FA03FD ;compressed chunk 0000 ;end of compressed stream variant 2.: 00 ;data are uncompressed 00000000 00000000 ;unknown data - always zero? FFFFFFFF ;raw uncompressed ARGB data
where the decompressed data are pixels with storage type: ARGB, so with the size info it should be enough to get the image from it. It's using ZLIB compression (www.zlib.net) Flash is using compression level 1, but it's possible to use any level (but it's not necessary as the sources are normally compressed altogether.
- SOUNDS are stored in DAT files in RAW format, it's possible to make WAV files from it easily using the information from the DOMSoundItem.
- The rest is unknown yet.
The rest of the *.dat types is unknown yet.
The name of the DAT files is important as well! Flash somehow gets numbers from the name, using name like checksum in hexadecimal form (9BB551621D3E2138FECA2F04469531D7.dat) crashes Flash! Using chars like [_.-] will cause the content unloadable as well (but not crash)

- 937
- 1
- 9
- 24
-
With CS5.5 I have found, that image in DAT file can start with 0303 - I don't know what it means yet:/ – Oldes Jun 02 '11 at 14:57
-
Hey Oldes, great info. Wondering if you ever got any further with this. – Jono Sep 03 '13 at 21:06
-
1Unfortunately no, I ended at state, which was enough for my needs. Also these days I usually don't need to extract images from XFL, I rather use JSFL script to export images or sounds from opened document. – Oldes Sep 04 '13 at 15:59
The names of the files are not in their own significant, but you of course need to find the references to the file names in other (usually xml) files.

- 11
- 1
-
1Maybe there are not significant, but you cannot use any name if you want to create a new one - import a new image into XFL automatically – Oldes Feb 19 '12 at 07:10