# chrome异步加载本地json文件报错:cross origin request are only supported for HTTP
2017-02-22 11:27
471 查看
问题:定义了一个studentInfo.json文件存储学生相关信息,在index.html中想通过
思考: google一下,似乎是Ajax跨域问题。
什么叫跨域?字面理解,跨是跨越,域是别的服务器,跨域就是到别的服务器上取东西。报错的意思应该就是chrome下,跨域请求只能通过通过这些协议标准实现:http、data、https、chrom-extension、chrom-extension-resource。
只要协议、域名、或端口有任何一个不同,就会被当做是不同的域。
但是仔细再一想,我请求的是本地文件啊,没有通过服务器请求啊,应该不算跨域么?什么鬼
再查发现,chrome在读取本地相对路径脚本时,禁止向第三方请求数据。 (只要是通过
好吧,那就知道怎么解决了。
解决一:
在sublime里面 启动sublimeServer,开启服务器模式,在浏览器中通过
好奇助我成长,顺手拖进火狐测了一下,并没有报错
FireFox : 允许读取本地相对路径脚本。
解决二:
查资料,发现还有一种解决方法,不用启动服务器模式,直接更改chrome的设置就行。
在chrome属性设置中,添加启动参数:
设置方法:chrome快捷方式–右键“属性”–快捷方式–目标
$.getJSON("studentInfo.json" , function(data){...})方法获取并显示json文件中的内容。结果运行后chrome报错如下:
思考: google一下,似乎是Ajax跨域问题。
什么叫跨域?字面理解,跨是跨越,域是别的服务器,跨域就是到别的服务器上取东西。报错的意思应该就是chrome下,跨域请求只能通过通过这些协议标准实现:http、data、https、chrom-extension、chrom-extension-resource。
只要协议、域名、或端口有任何一个不同,就会被当做是不同的域。
但是仔细再一想,我请求的是本地文件啊,没有通过服务器请求啊,应该不算跨域么?什么鬼
再查发现,chrome在读取本地相对路径脚本时,禁止向第三方请求数据。 (只要是通过
file://方式访问,或者直接拖进浏览器访问,都叫本地运行) 什么叫第三方?那就是不管本地文件、还是服务器
url文件都不行。
好吧,那就知道怎么解决了。
解决一:
在sublime里面 启动sublimeServer,开启服务器模式,在浏览器中通过
localhost:8080/index.html访问,再看 debug tool,没有报错了,完美!~成功访问到本地json文件。
好奇助我成长,顺手拖进火狐测了一下,并没有报错
FireFox : 允许读取本地相对路径脚本。
解决二:
查资料,发现还有一种解决方法,不用启动服务器模式,直接更改chrome的设置就行。
在chrome属性设置中,添加启动参数:
--allow-file-access-from-files: 允许本地Ajax请求,也叫file协议下的Ajax请求
--enable-file-cookies: 允许chrome保存本地设置cookie
设置方法:chrome快捷方式–右键“属性”–快捷方式–目标
相关文章推荐
- jquery读取本地文件,Windows上报错。XMLHttpRequest cannot load xxx. Cross origin requests are only supported for protocol schemes: http, data, chrome, chrome-extension, https, chrome-extension-resource.k.cors.a.c
- 关于Chrome浏览器使用ajax访问本地文件报 Cross origin requests are only supported for HTTP
- nodejs报错 XMLHttpRequest cannot load localhost:3000/test_date/. Cross origin requests are only supported for protocol schemes: http, data, chrome, chrome-extension, https.
- XMLHttpRequest cannot load file://app.json. Cross origin requests are only supported for HTTP.
- Ajax本地跨域问题 Cross origin requests are only supported for HTTP
- Cross origin requests are only supported for protocol schemes: http, data, chrome, chrome-extension,
- 用临时用户数据目录启动Chrome,关闭安全检查等(解决Cross origin requests are only supported for HTTP?)
- Ajax本地跨域问题 Cross origin requests are only supported for HTTP
- Cross origin requests are only supported for protocol schemes: http, data, chrome, chrome-extension,
- Cross origin requests are only supported for protocol schemes: http, data, chrome-extension, https
- Ajax本地跨域问题 Cross origin requests are only supported for HTTP
- 关于XMLHttpRequest cannot load xxx . Cross origin requests are only supported for protocol schemes...
- 【Google Chrome】 Cross origin requests are only supported for protocol schemes: http, data, chrome, c
- 【chrome错误】Cross origin requests are only supported for protocol schemes: http, data,chrome-extension, https, chrome-extension-reso
- 【Google Chrome】 Cross origin requests are only supported for protocol schemes: http, data, chrome, chrome-extension, https, chrome-extension-resource问题解决
- ajax请求 Cross origin requests are only supported for protocol schemes: http, data, chrome, chrome-ext
- XMLHttpRequest cannot load file. Cross origin requests are only supported for HTTP angularjs
- 【Google Chrome】 Cross origin requests are only supported for protocol schemes: http, data, chrome, chrome-extension, https, chrome-extension-resource问题解决
- Ajax本地跨域问题 Cross origin requests are only supported for HTTP
- Cross origin requests are only supported for protocol schemes: http, data, chrome, chrome-extension