Mike Hordecki
Mike Hordecki

Reputation: 97101

Downloading a variable

Is it possible, in Javascript, to prompt user for downloading a file that isn't actually on the server, but has contents of a script variable, instead?

Something in spirit with:

var contents = "Foo bar";
invoke_download_dialog(contents, "text/plain");

Cheers,

MH

Upvotes: 8

Views: 836

Answers (6)

Mark A. Nicolosi
Mark A. Nicolosi

Reputation: 85571

See the accepted answer to my question here. This is only possible in IE browsers.

document.execCommand('SaveAs',true,'file.xml')

Upvotes: 2

Stewart
Stewart

Reputation: 4044

javascript: URIs should work for this - indeed, this is exactly what they're meant for. However, IE doesn't honour the type attribute, and in Safari this technique has no effect at all.

data: URIs work in Firefox (3.0.11) and Safari (4.0) (and probably other compliant browsers), but I can't get this approach to work in IE (8.0). (All tested in Windows)

<a href="data:text/plain,The%20quick%20brown%20fox%20jumps%20over%20the%20lazy%20dog.">Data URI</a>

This isn't a JS solution in itself, but JS can be used to set the href dynamically. Use the escape function to turn raw text/data into URI-encoded form.

Combining this with detecting IE and using the IE-specific solution already linked to might do what you want....

I shall add that you can't force it to trigger a download dialog (that's beyond the scope of both HTML and JS), but you can persuade it to do so by setting application/octet-stream as the type. Trouble is that the user'll then have to add the right filename extension manually.

Upvotes: 3

Ateş G&#246;ral
Ateş G&#246;ral

Reputation: 140050

Check out jsPDF; it allows downloading (or embedded viewing) of PDF files that are entirely generated inside the browser. They claim: "Client-side demo works best in Safari or iPhone Safari. Also works Firefox 3 on Windows and Opera. IE support on the way." So, they seem to have a handle on how to invoke downloads in major browsers.

Upvotes: 0

Williham Totland
Williham Totland

Reputation: 29009

A possible option would be to use JavaScript to generate a link with a href using the data: URL scheme, tho' this might require some fancy coding to pull off properly.

Upvotes: 2

Dana the Sane
Dana the Sane

Reputation: 15198

Keep in mind, if any cross site scripting vulnerability exists on the page, the variable could be overwritten with malicious data. Although the resulting file's content type would still need to be by-passed for an executable, there's still risk.

I think that a safer way to do this would be to use Joel's answer and to perform validation on the posted data before sending it to the user.

Upvotes: 1

Joel Martinez
Joel Martinez

Reputation: 47749

not specifically via javascript, but you could post the variable's value to a server-side page that would force the user to download the contents as text.

Upvotes: 1

Related Questions