I would like to know if I can create a text file and save the file in the users "Downloads" section in his/her computer using javascript. The way my feature should work is when the user clicks the submit button, I populate the users info in the text file and then save it in his machine. I would like this to work in google chrome.
Is this possible? I have seen posts that specifically tell me that it is a serious security issue.
The following method works in IE11+, Firefox 25+ and Chrome 30+:
See this in Action: http://jsfiddle.net/Kg7eA/
Firefox and Chrome support data URI for navigation, which allows us to create files by navigating to a data URI, while IE doesn't support it for security purposes.
On the other hand, IE has API for saving a blob, which can be used to create and download files.
This link helped me a lot and solved my problem. Cross browser solution:
https://www.thewebflash.com/reading-and-creating-text-files-using-the-html5-file-api/
This is the most relevant part:
No, as that would allow you to create malicious programs in the client's computer, and harm his privacy.
Also, requests to download files come from the server, so you'll need to create the file on the server, and serve it to the user, and hope he'll save it (if he requested for it it's likely that he will).
Another possible solution to look at is to use data URIs or CSVs, but browser support for them is incomplete (IE), see Create a file in memory for user to download, not through server
Try this:
if you want to set the filename use
download
attribute of anchor tag:Enter this into the Chrome browser
So to construct the download for your users you would do something like
data='<a href='data:text;charset=utf-8,'+uriEncode(yourUSERdataToDownload)+' >Your Download</a>
Then inject it into the dom for your user to press.
You will need server side functionality in order to server the user a text file (javascript is not enough). You can create a server side script that creates the file and use javascript in order to prompt user to save it.