Fighting against Internet Explorer

I'm trying to embed some image files into an HTML document (in fact, in a XML document but I use HTML for my tests).

So far, this is what I've done:

Using the data: scheme.

According to RFC2397, you can use the following to display an embedded image:

<img src="data:image/xbm,#define cursor_width 16\n#define cursor_height 16\nstatic unsigned char cursor_bits[] = { 0x03, 0x00, 0x0d, 0x00, 0x32, 0x00, 0xc6, 0x00, 0x0c, 0x03, 0x14, 0x0c, 0x28, 0x30, 0x58, 0xc0, 0xb0, 0x80, 0x50, 0x41, 0xa0, 0x22, 0x60, 0x45, 0xc0, 0x8a, 0x40, 0x55, 0x80, 0x2a, 0x80, 0x11};" />

or

<img src="" />

(base64 encoded GIF file)

...unfortunately, it doesn't work in Internet Explorer :-(

Using Javascript

The following page contains an embedded JPEG file and uses the javascript: URL scheme:

<html>
<head>
<!-- Hide file storage elements -->
<style type="text/css">
.base64 {
 display:none;
 visibility:hidden;
}
</style>
<script type="text/javascript">
var keyStr = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=";
function decodeImg(name) {
var inp = document.getElementById(name).innerHTML.replace(/[^A-Za-z0-9+/\=]/g, "");
var out = "";
var chr1, chr2, chr3 = "";
var enc1, enc2, enc3, enc4 = "";
var i = 0;
do {
    enc1 = keyStr.indexOf(inp.charAt(i++));
    enc2 = keyStr.indexOf(inp.charAt(i++));
    enc3 = keyStr.indexOf(inp.charAt(i++));
    enc4 = keyStr.indexOf(inp.charAt(i++));
    chr1 = (enc1 << 2) | (enc2 >> 4);
    chr2 = ((enc2 & 15) << 4) | (enc3 >> 2);
    chr3 = ((enc3 & 3) << 6) | enc4;
    out = out + String.fromCharCode(chr1);
    if (enc3 != 64) {
        out = out + String.fromCharCode(chr2);
    }
    if (enc4 != 64) {
        out = out + String.fromCharCode(chr3);
    }
    chr1 = chr2 = chr3 = "";
    enc1 = enc2 = enc3 = enc4 = "";
} while (i < inp.length);
return out;
}
</script>
</head>
<body>

<!-- The image file, base64-encoded -->
<div class="base64" id="test1.jpg">
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
</div>
<img src="javascript:decodeImg('test1.jpg')" />
</body>
</html>

...however, this doesn't work in Internet Explorer (seems it's something wrong with its handling of NUL characters) :-(

Web archives

Next step is to try to fool Internet Explorer by using <meta> tags to pass attachments directly… Wish me luck! :-/

DOM/ActiveX or Java

As a last resort solution, I'm investigating Windows ActiveX components that can be fed with raw data. An alternative would be to package everything within an executable JAR file with the HTML viewer…

Powered by Blogger.