网络编程 | 站长之家 | 网页制作 | 图形图象 | 操作系统 | 冲浪宝典 | 软件教学 | 网络办公 | 邮件系统 | 网络安全 | 认证考试 | 系统进程
Firefox | IE | Maxthon | 迅雷 | 电驴 | BitComet | FlashGet | QQ | QQ空间 | Vista | 输入法 | Ghost | Word | Excel | wps | Powerpoint
asp | .net | php | jsp | Sql | c# | Ajax | xml | Dreamweaver | FrontPages | Javascript | css | photoshop | fireworks | Flash | Cad | Discuz!
当前位置 > 网站建设学院 > 网页制作 > Javascript
网页制作:Dreamweaver教程,FrontPages教程,Javascript教程,HTML教程,CSS教程,心得技巧,DHTML教程,网页特效,Discuz!论坛
本月文章推荐
.Javascript实例教程(1) 创建弹出.
.javascript的作用域.
.网页表单自动填写技术(gmail为例).
.JavaScript面向对象 “四段式”类.
.小谈JavaScript和JScript.
.通过javascript在光标处插入文本.
.Javascript正则表达式的3个例子.
.网页常用小技巧—javascript篇.
.提高代码性能技巧谈—以创建千行.
.用Javascript实现评估用户输入密.
.Javascript控制文本框的输入法切.
.125个常用javascript语句.
.利用javascript从数据库取数据来.
.javascript eval().
.javascript判断上传图片的大小和.
.将金额小写转化成汉字大写的实现.
.Javascript实现的自动验证函数.
.JavaScript学习:基础继承机制.
.关于Javascript定义函数和this使.
.给select控件在指定位置插入opti.

Javascript使用CSS异步跨域获取数据

发表日期:2008-11-24


这是个非常“猥琐”的异步获取数据的方法,原理是通过动态载入一段 CSS,然后解析其中的字段提取数据(DEMO)。

先来说说它的优点。首先是跨域,数据获取的实质其实就是载入一段 CSS 。其次避免了类似 JSONP 的跨站脚本注入攻击。

然后考虑下可能会出现的问题。首先是通过 rawurlencode 编码过的数据容量会大很多,而且不可读。

其次,如果使用不当可能会影响页面渲染,看作者的 Javascript 代码中加入了段

e.setAttribute("media", "print, csshttprequest");很有意思。还有就是使用

@import url(about:chr:data);真的让人感觉太太“猥琐”了。

原官方有个 Python 编写的 Encoder 实现,我顺便将其成了 PHP ,下面是相应的代码

function css_request_encode($str) {
    $prefix = 'about:chr:';
    $length = 2000 - strlen($prefix); // Internet Explorer 2KB URI limit
    for ($i = 0, $encode = ''; $slice = substr($str, $i * $length, $length); $i++) {
        $encode .= sprintf("@import url('$prefix%s');n", rawurlencode($slice));
    }
    return $encode;
}

上一篇:网页中Javascript代码的应用方式 人气:644
下一篇:JAVASCRIPT中的window.location和document.location 人气:601
浏览全部Javascript的内容 Dreamweaver插件下载 网页广告代码 祝你圣诞节快乐 2009年新年快乐