I’ve got a large form where the user is allowed to input many different fields, and when they’re done I need to send the contents of the form to the server, process it, and then spit out a .txt file containing the results of the processing for them to download. Now, I’m all set except for the download part. Setting the headers on the response to the jQuery .post() doesn’t seem to work. Is there any other way than doing some sort of iframe trick to make this work (a la JavaScript/jQuery to download file via POST with JSON data)?
Again, I’m sending data to the server, processing it, and then would like to just echo out the result with headers to prompt a download dialog. I don’t want to write the result to disk, offer that for download, and then delete the file from the server.
Don’t use AJAX. There is no cross-browser way to force the browser to show a save-as dialog in JavaScript for some arbitrary blob of data received from the server via AJAX. If you want the browser to interpret the results of a HTTP POST request (in this case, offering a download dialog) then don’t issue the request via AJAX.
If you need to perform some kind of validation via AJAX, you’ll have to do a two step process where your validation occurs via AJAX, and then the download is started by redirecting the browser to the URL where the .txt file can be found.