浏览器跨域获取Lrc歌词数据的解决办法
网络编程 2021-07-05 10:36www.168986.cn编程入门
获取同一个域的数据,可以通过XMLHTTP组件或IFRAME来实现,不存在跨域访问的权限问题,比较简单。
但如果要访问不同域的数据时,由于浏览器的安全设置,XMLHTTP没有权限获取数据,而IFRAME没有权限将获取的数据传递给父窗口,似乎没有其它解决办法。
顿悟……
网页内引用不同域的脚本并不会提示权限不足,对了,就是它没错!
解决方法找到了,现在来简单测试一下
在51js.服务器上新建一页面(Test.html)。
[Ctrl+A 全选 注:]
解释两个关键点
1. lastScript用于存放上次建立的script节点的ID,在下次要再新建script节点时,要删除上次建立的节点,以免加载的脚本越来越多,占用过多的内存。
2. url后面加了一个数值d是为了防止浏览器缓存脚本数据,在本例中可以不加,如果脚本是由服务器动态生成的,那最好加上。
然后再建立两个java script脚本用于测试。
alert.js
alert('You can see me!');
info.js
g('myname').value='谱乐视听';
g('myblog').value='.aboutplayer.';
好了,谱乐已把它们放在aboutplayer.服务器下,这样它们和Test.html就不在同一个域内了。
用浏览器打开Test.html文件。
点击“Test Alert”,应该会弹出对话框显示You can see me!。
点击“Get My Info”,应该会在文本框中显示本站的信息。
进而,若把Lrc歌词数据放入Js脚本文件中(不是直接更改文件扩展名),就可实现跨域获取Lrc歌词数据了。
但如果要访问不同域的数据时,由于浏览器的安全设置,XMLHTTP没有权限获取数据,而IFRAME没有权限将获取的数据传递给父窗口,似乎没有其它解决办法。
顿悟……
网页内引用不同域的脚本并不会提示权限不足,对了,就是它没错!
解决方法找到了,现在来简单测试一下
在51js.服务器上新建一页面(Test.html)。
[Ctrl+A 全选 注:]
解释两个关键点
1. lastScript用于存放上次建立的script节点的ID,在下次要再新建script节点时,要删除上次建立的节点,以免加载的脚本越来越多,占用过多的内存。
2. url后面加了一个数值d是为了防止浏览器缓存脚本数据,在本例中可以不加,如果脚本是由服务器动态生成的,那最好加上。
然后再建立两个java script脚本用于测试。
alert.js
alert('You can see me!');
info.js
g('myname').value='谱乐视听';
g('myblog').value='.aboutplayer.';
好了,谱乐已把它们放在aboutplayer.服务器下,这样它们和Test.html就不在同一个域内了。
用浏览器打开Test.html文件。
点击“Test Alert”,应该会弹出对话框显示You can see me!。
点击“Get My Info”,应该会在文本框中显示本站的信息。
进而,若把Lrc歌词数据放入Js脚本文件中(不是直接更改文件扩展名),就可实现跨域获取Lrc歌词数据了。
上一篇:一个封装的Ajax类
下一篇:AJAX技术基础介绍
编程语言
- 宿迁百度关键词排名指南:实现精准营销的关键
- 四川SEO优化怎么做网络推广
- 立昂技术备案老域名收购:如何为您的业务赋能
- 安徽百度关键词seo贵不贵,一般需要多少钱
- 吉林百度快照排名怎么做电话营销
- 多伦新手做SEO怎么做
- 甘肃优化关键词排名推广怎么做论坛营销
- 沙雅SEO网站推广:提升您的在线可见性
- 四川SEO优化如何提升销售额和销售量
- 聂荣网站排名优化:提升网站可见性的全方位指
- 涞水SEO:提升地方企业在线可见性的策略
- 辽宁百度seo排名怎样做网站排名
- 临湘哪有关键词排名优化:提升网站可见度的关
- 黑龙江百度网站优化有没有优惠
- 凉城优化关键词排名推广:提升您的网络可见性
- 萝北整站优化:提升您网站流量和排名的全面指