网络编程 | 站长之家 | 网页制作 | 图形图象 | 操作系统 | 冲浪宝典 | 软件教学 | 网络办公 | 邮件系统 | 网络安全 | 认证考试 | 系统进程
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!
当前位置 > 网站建设学院 > 网络编程 > Ajax
Tag:注入,存储过程,分页,安全,优化,xmlhttp,fso,jmail,application,session,防盗链,stream,无组件,组件,md5,乱码,缓存,加密,验证码,算法,cookies,ubb,正则表达式,水印,索引,日志,压缩,base64,url重写,上传,控件,Web.config,JDBC,函数,内存,PDF,迁移,结构,破解,编译,配置,进程,分词,IIS,Apache,Tomcat,phpmyadmin,Gzip,触发器,socket
网络编程:ASP教程,ASP.NET教程,PHP教程,JSP教程,C#教程,数据库,XML教程,Ajax,Java,Perl,Shell,VB教程,Delphi,C/C++教程,软件工程,J2EE/J2ME,移动开发
本月文章推荐
.使用AJAX技术打造博客无刷新搜索.
.asp.net ajax 和 asp.net 2.0中的.
.争论:Ajax技术是否即将没落?.
.一些常用的Ajax框架.
.轻松实现无刷新三级联动菜单[VS2.
.AJAX在Post中文的时候解决乱码的.
.ASP.NET AJAX中的非同步PageMeth.
.初步了解 ASP.NET AJAX 扩展.
.ajax的server部分(php版).
.利用PHP+JavaScript打造AJAX搜索.
.解开Ajax技术生命中的达芬奇密码.
.[四天学会ajax] 学习Ajax教程第四.
.Asp.net Ajax 中的脚本错误: Sys.
.asp.net ajax 使用updatepanel进.
.Ajax+GridView+Xml的简易留言薄.
.用 PHPRPC 实现 Ajax 级联下拉菜.
.漫谈Ajax在.Net中的使用.
.微软Asp.net Ajax 1.0的AutoComp.
.通过PHP和Sajax使用Ajax之JavaSc.
.利用ICallbackEventHandle实现类.

ajax实现垮域访问初探

发表日期:2007-12-26


这个应该归到javascript的安全性问题一般服务器A设置的是不允许别的域的机器B执行B上的ajax调用服务器A上的资源原因,可以举个简单的安全隐患例子:
假设ajax可以垮域访问,那么我在自己机器上可以写ajax请求Google各类web应用中的资源比如先用firefox研究GMail在登录过程中大量ajax请求的地址以及参数,可以得到用户cookie的验证过程然后写js去跨域获取别的用户的cookie,这样可以绕过用户的GMail密码而登入他人的GMail邮箱

那么有了ajax跨域限制,是不是就真的不能做ajax垮域访问了?
ajax垮域确实不行,但是我们可以中转实现,也就是所谓的代理
原理很简单,在自己的js跟远程服务器A的资源之间架设一个自己的容器
可以用asp、php、java、.net等所有可以的动态web语言
以asp为例(获取热得快网站某个用户的好友列表,返回xml数据格式)

<%
p = "http://redekuai.com/api/user_friends_xml/funy"
Response.BinaryWrite ZQcnGet(p)
Response.Flush
Function ZQcnGet(url)
Set Retrieval = CreateObject("Microsoft.XMLHTTP")
With Retrieval
.Open "Get", url, False, "", ""
.Send
ZQcnGet = .ResponseBody
End With
Set Retrieval = Nothing
End Function
%>
这段代码保存为一个proxy.asp,然后放到IIS里,这个时候就可以随便找个机器写js了,用ajax请求proxy.asp,最后相当于实现了ajax垮域访问
php的示例代码更简单
echo file_get_contents("http://redekuai.com/api/user_friends_xml/funy"");
?>
注:php版本需要>= 4.3.0

再给个asp.net(C#)版本的示例代码:

using System.Net;
using System.IO;
using System.Text;
public partial class ajaxpages: System.Web.UI.Page
{
    protected void Page_Load(object sender, EventArgs e)
    {
        WebRequest wr = WebRequest.Create("http://redekuai.com/api/user_friends_xml/funy");
        WebResponse wres = wr.GetResponse ();
        Encoding resEncoding = System.Text.Encoding.GetEncoding("utf-8");
        StreamReader sr = new StreamReader(wres.GetResponseStream(), resEncoding);
        string html = sr.ReadToEnd();
        Response.Write(html);
        sr.Close();
        wres.Close();
    }
}
分别为proxy.asp proxy.php proxy.aspx
那么做好代理,实现了自己一般机器(非web服务器)上js垮域访问远程网站资源有什么实际的意义呢?
要知道,现在的互联网技术已经进入了绝对的Mashup时代
老美有2k多个公司靠做facebook的APP存活着,国外的这种产业链真的不能在国内发展吗?要知道5年后互联网也会成为中国的基础设施了
已经有做的比较好的web2.0站点在开放API(又拍、热得快)或者准备开放

上一篇:ASP.NET AJAX中的非同步PageMethod调用 人气:4790
下一篇:如何在jsp中使用 jquery 的 ajax 功能 人气:5631
浏览全部ajax的内容 Dreamweaver插件下载 网页广告代码 祝你圣诞节快乐 2009年新年快乐