XMLHttpRequest Origin null is not allowed Access-Control-Allow-Origin for file:/// to file:/// (Serverless)
Asked Answered
P

10

210

I'm trying to create a website that can be downloaded and run locally by launching its index file.

All the files are local, no resources are used online.

When I try to use the AJAXSLT plugin for jQuery to process an XML file with an XSL template (in sub directories), I receive the following errors:

XMLHttpRequest cannot load file:///C:/path/to/XSL%20Website/data/home.xml. Origin null is not allowed by Access-Control-Allow-Origin.

XMLHttpRequest cannot load file:///C:/path/to/XSL%20Website/assets/xsl/main.xsl. Origin null is not allowed by Access-Control-Allow-Origin.

The index file making the request is file:///C:/path/to/XSL%20Website/index.html while the JavaScript files used are stored in file:///C:/path/to/XSL%20Website/assets/js/.

How can I do to fix this issue?

Prud answered 17/11, 2010 at 19:52 Comment(0)
O
178

For instances where running a local webserver is not an option, you can allow Chrome access to file:// files via a browser switch. After some digging, I found this discussion, which mentions a browser switch in opening post. Run your Chrome instance with:

chrome.exe --allow-file-access-from-files

This may be acceptable for development environments, but little else. You certainly don't want this on all the time. This still appears to be an open issue (as of Jan 2011).

See also: Problems with jQuery getJSON using local files in Chrome

Onward answered 20/1, 2011 at 20:52 Comment(5)
@Rich, glad it helped! I wonder if there will be greater demand for this with Google's push toward browser-based apps. I think demand will only grow.Onward
this was helpful for macs OS X cweagans.net/blog/2011/1/24/…Monogenetic
Thanks, I was wondering where I coded wrong, seems browser is the issue.Undulate
Is there any reason --allow-file-access-from-files would not fix the issue. I am simply trying to load a script file like so $.getScript("application.js"); and get the error described in the question.Alfano
This works, however "Before you execute the command, make sure all of your Chrome window is closed and not otherwise running. Or, the command line param would not be effective. "chrome.exe --allow-file-access-from-files"" (https://mcmap.net/q/128884/-problems-with-jquery-getjson-using-local-files-in-chrome)Nucleolus
C
86

Essentially the only way to deal with this is to have a webserver running on localhost and to serve them from there.

It is insecure for a browser to allow an ajax request to access any file on your computer, therefore most browsers seem to treat "file://" requests as having no origin for the purpose of "Same Origin Policy"

Starting a webserver can be as trivial as cding into the directory the files are in and running:

python -m http.server

[Edit Thanks @alextercete, for pointing out that it has updated in Python3]

Counselor answered 25/11, 2010 at 12:14 Comment(4)
I'm hoping to develop a solution that does not require the user to use anything more than their web browser. Using Python, any interpreter, or any non system agnostic software is not viable.Prud
Well the only other solution I can think of is to load the entire thing in one single page so that you don't need to make any ajax requests to the file system.Counselor
Thank you @Counselor ! I'm using your solution and it's very handy !Slogan
And if you are using Python 3, the command would be python -m http.server.Educable
S
5

This solution will allow you to load a local script using jQuery.getScript(). This is a global setting but you can also set the crossDomain option on a per-request basis.

$.ajaxPrefilter( "json script", function( options ) {
  options.crossDomain = true;
});
Sedimentary answered 22/8, 2013 at 10:19 Comment(1)
worked like a charm for loading a local js file from a local html file! thanks, exactly what i needed.Bettyannbettye
L
5

What about using the javascript FileReader function to open the local file, ie:

<input type="file" name="filename" id="filename">
<script>
$("#filename").change(function (e) {
  if (e.target.files != undefined) {
    var reader = new FileReader();
    reader.onload = function (e) {
        // Get all the contents in the file
        var data = e.target.result; 
        // other stuffss................            
    };
    reader.readAsText(e.target.files.item(0));
  }
});
</script>

Now Click Choose file button and browse to the file file:///C:/path/to/XSL%20Website/data/home.xml

Lawrenson answered 31/5, 2014 at 0:25 Comment(0)
O
4

Here is an applescript that will launch Chrome with the --allow-file-access-from-files switch turned on, for OSX/Chrome devs out there:

set chromePath to POSIX path of "/Applications/Google Chrome.app/Contents/MacOS/Google Chrome"    
set switch to " --allow-file-access-from-files"
do shell script (quoted form of chromePath) & switch & " > /dev/null 2>&1 &"
Oakland answered 9/8, 2011 at 5:12 Comment(1)
You can just use open(1) to add the flags: open -a 'Google Chrome' --args --allow-file-access-from-files.Benzol
C
3

Launch chrome like so to bypass this restriction: open -a "/Applications/Google Chrome.app/Contents/MacOS/Google Chrome" --args --allow-file-access-from-files.

Derived from Josh Lee's comment but I needed to specify the full path to Google Chrome so as to avoid having Google Chrome opening from my Windows partition (in Parallels).

Chandigarh answered 14/7, 2014 at 6:1 Comment(0)
W
2

The way I just worked around this is not to use XMLHTTPRequest at all, but include the data needed in a separate javascript file instead. (In my case I needed a binary SQLite blob to use with https://github.com/kripken/sql.js/)

I created a file called base64_data.js (and used btoa() to convert the data that I needed and insert it into a <div> so I could copy it).

var base64_data = "U1FMaXRlIGZvcm1hdCAzAAQA ...<snip lots of data> AhEHwA==";

and then included the data in the html like normal javascript:

<div id="test"></div>

<script src="base64_data.js"></script>
<script>
    data = atob(base64_data);
    var sqldb = new SQL.Database(data);
    // Database test code from the sql.js project
    var test = sqldb.exec("SELECT * FROM Genre");
    document.getElementById("test").textContent = JSON.stringify(test);
</script>

I imagine it would be trivial to modify this to read JSON, maybe even XML; I'll leave that as an exercise for the reader ;)

Wallen answered 29/10, 2015 at 2:14 Comment(0)
C
1

You can try putting 'Access-Control-Allow-Origin':'*' in response.writeHead(, {[here]}).

Caundra answered 25/7, 2013 at 8:6 Comment(1)
where does response.writeHead come from, how do I call it and where? Can you give more examples? Keep in mind this is a local file system not a server. My understanding is that value can only be set from a server?Walczak
I
0

use the 'web server for chrome app'. (you actually have it on your pc, wether you know or not. just search it in cortana!). open it and click 'choose file' choose the folder with your file in it. do not actually select your file. select your files folder then click on the link(s) under the 'choose folder' button.

if it doesnt take you to the file, then add the name of the file to the urs. like this:

   https://127.0.0.1:8887/fileName.txt

link to web server for chrome: click me

Inseparable answered 30/8, 2019 at 2:31 Comment(0)
A
0

If you only need to access the files locally then you can include the exact path to the file, rather than using

../images/img.jpg

use

C:/Users/username/directoryToImg/img.jpg

The reason CORS is happening is because you are trying to traverse to another directory within a webpage, by including the direct path you are not changing directory, you are pulling from a direct location.

Auriferous answered 25/11, 2020 at 22:49 Comment(0)

© 2022 - 2024 — McMap. All rights reserved.