在Firefox中通过AJAX跨域访问Web资源

简介:
一、解决在firefox 中无法跨域访问的问题
AJAX 从本质上讲就是命名用XMLHttpRequest 组件来向服务端发送HTTP 请求,请接收相应信息。至于成功接收到响应信息后的操作,就和普通的Web 客户端程序类似了(一般用DOM 将信息加到HTML 组件中)。但问题就发生在了XMLHttpRequest 组件上。虽然在大多数浏览器中(包括IE Firefox 等)都叫这个名子。使用方法也类似。但在进行某些操作时却有不同的效果。
就拿跨域访问的问题来说。让我们先看看如下的html 中的javascript 代码:
test.html

< html >
    
< head >
        
< title ></ title >
        
< meta  http-equiv ="Content-Type"  content ="text/html; charset=UTF-8" >
< script  type ="text/javascript" >   

//  获得IE和firefox浏览器中的XMLHttpRequest对象
function  getXMLHTTPRequest()
{
    var  myRequest  =   null ;
    if (window.XMLHttpRequest)    //  firefox
    {        
        myRequest 
=   new  XMLHttpRequest(); 
    }
    else   if ( typeof  ActiveXObject  !=   " #ff0000 " )   //  IE
    {              
        myRequest 
=   new  ActiveXObject( " Microsoft.XMLHTTP " );
    }          
    return  myRequest;          
}

var  myRequest;
function  onReadyState()    //  XMLHttpRequest处理异步访问状态时的事件
{
    if (myRequest.readyState  ==   4 )    //  4表示成功获得相应信息
    {              
        var  msg  =  document.getElementById( " msg " );
        msg.value 
=  myRequest.responseText             
    }
}
function  getServiceText()
{     
    myRequest 
=  getXMLHTTPRequest();
    if (myRequest)
    {         
        myRequest.onreadystatechange 
=  onReadyState;      
        try  
        {
            myRequest.open( 
" post " " http://www.blogjava.net " true );
        }
        catch (exception)
        {
            
var  msg  =  document.getElementById( " msg " );
            msg.value 
=  exception;  
         } 
         myRequest.send(
" test " );
    }         
}

</ script >
    
</ head >
    
< body >
        
< input  id ="msg"  type ="text"   />
        
< input  type ="button"  value ="信息"  onclick ="getServiceText()"   />
    
</ body >
</ html >
如果在IE 中访问上面的html 文件,url 如下:
http://localhost:8080/test.html
会弹出一个对话框,大概意思是说您已经跨域访问了,可能存在风险,是否继续。如果继续执行的话,仍然可以访问http://www.blogjava.net 。但是在firefox 中却更本无法访问其它域的url ,并且会抛出“调用方法  XMLHttpRequest.open  时权限不足”异常。解决的方法一般有两种,一种是修改firefox 的设置,在firefox 的地址栏中输入“about:config ”,并找到signed.applets.codebase_principal_support ,将其设为true 。如图1 所示。


                                                       
                                         图1
但这种方法经过实现,仍然无法访问其他域的 url ,不知是不是新版的 firefox 把这个给屏蔽了。就算这种方法可行,也尽量不使用这种需要配置 firefox 的方法,而要使用编程的方法,在访问其它域之前,可以使用如下代码打开权限:

try  

    netscape.security.PrivilegeManager.enablePrivilege(
" UniversalBrowserRead " ); 
}
catch  (exception)

    alert(exception); 
}

要注意的是,上面的代码只能用在 firefox 中,因此,要将其放到只有 firefox 才能执行到的代码块中,如在下面的块中:

if (window.XMLHttpRequest)    //  firefox
{        
    
try  
    { 
        netscape.security.PrivilegeManager.enablePrivilege(
" UniversalBrowserRead " ); 
    }
    
catch  (exception)
    { 
        alert(exception); 
    }
}

     不能将上面的代码放到getXMLHTTPRequest 中,应放到getServiceText 中。
注:如果test.html 在通过web 服务器访问,而是按着访问本地文件时访问test.html 时,在IE 中不会出现上述的提示对话框,而是直接就可以访问其他的域。
二、其他的跨浏览器问题
 
不同浏览器的XMLHttpRequest 虽然接口一样,但在不同浏览器中调用XMLHttpRequest 的方法和属性的效果不同。如send 方法,在IE 中可以不传参数,如myRequest.send(); 仍然可以正常工作,而在firefox 中,必须为send 方法传一个参数,也就是说,在firefox send 方法参数没有默认值,必须为其赋值。为了通用起见,建议所有的send 方法都为其赋一个参数值,哪怕是空串。
除了send 方法,responseText 属性也是一样,在IE 中,responseText 返回了整个web 资源的内容,而在firefox 中只返回web 资源的第一行。







 本文转自 androidguy 51CTO博客,原文链接:http://blog.51cto.com/androidguy/215351,如需转载请自行联系原作者


相关文章
|
2月前
计算机网络:思科实验【1-访问WEB服务器】
计算机网络:思科实验【1-访问WEB服务器】
计算机网络:思科实验【1-访问WEB服务器】
|
1月前
|
网络协议 Shell 网络安全
实验目的1.编译安装httpd2.优化路径3.并将鲜花网站上传到web服务器为网页目录4.在客户机访问网站http://www.bdqn.com
实验目的1.编译安装httpd2.优化路径3.并将鲜花网站上传到web服务器为网页目录4.在客户机访问网站http://www.bdqn.com
163 0
|
1月前
|
Windows
Windows Server 各版本搭建 Web 服务器实现访问本地 Web 网站(03~19)
Windows Server 各版本搭建 Web 服务器实现访问本地 Web 网站(03~19)
53 2
|
2月前
|
关系型数据库 MySQL 应用服务中间件
【IIS搭建网站】在本地电脑上搭建web服务器并实现外网访问
在网上各种教程和介绍中,搭建网页都会借助各种软件的帮助,比如网页运行的Apache和Nginx、数据库软件MySQL和MSSQL之类,为方便用户使用,还出现了XAMPP、PHPStudy、宝塔面板等等一系列集成服务,都是为了方便我们能快速建立网站。是不是不适用这些软件就无法建立网站了呢?答案当然是否定的,在Windows系统中实际上集成了建立网站所必须的软件环境。今天就让我们来看看,如何使用Windows自带的网站程序建立网站吧。
|
2月前
|
网络协议 Linux 网络架构
【Cisco Packet Tracer】访问 Web服务器
【Cisco Packet Tracer】访问 Web服务器
185 0
|
3月前
|
Ubuntu 网络协议 Linux
EVE-NG初次启动及WEB客户端访问
本章从虚拟机Eve模拟器启动、模拟器的启动配置、浏览器访问三个步骤讲解EVE-NG的首次启动。 1.启动模拟器 打开虚拟机环境,启动安装好的EVE-NG虚拟机,进入如下界面。
|
8月前
|
Linux 网络安全 Apache
怎么在树莓派上搭建web网站,并发布到外网可访问?
怎么在树莓派上搭建web网站,并发布到外网可访问?
138 0
|
3月前
|
设计模式 开发框架 前端开发
ajax应用设计模式,Ajax设计模式下Web开发的研究与应用
ajax应用设计模式,Ajax设计模式下Web开发的研究与应用
|
4月前
|
前端开发 Java 数据库连接
Spring 框架模块深度解析:核心容器、数据访问、Web 层与其他关键模块
Spring 可能成为您的所有企业应用程序的一站式商店。但是,Spring 是模块化的,允许您挑选适用于您的模块,而无需引入其他模块。下面的部分提供了 Spring Framework 中所有可用模块的详细信息。Spring Framework 提供了大约20个模块,可以根据应用程序要求使用。
60 0
|
4月前
|
前端开发 JavaScript Java
IDEA中修改了Web项目后,更新资源 类和资源 重新部署的区别
IDEA中修改了Web项目后,更新资源 类和资源 重新部署的区别
34 1