很多人在使用AJAX调用别人站点内容的时候,JS会提示"没有权限"错误,这是XMLHTTP组件的限制-安全起见
禁止访问非同域的网站,下面一个例子来访问http://www.google.cn,
<script type="text/javascript">
function createobj() {
if (window.ActiveXObject) {
return new ActiveXObject("Microsoft.XMLHTTP");
}
else if (window.XMLHttpRequest) {
return new XMLHttpRequest();
}
}
function getWebPage(url) {
var oBao=createobj();
var my_url=url
oBao.open('get',my_url,false);
oBao.onreadystatechange=function(){
if(oBao.readyState==4){
if(oBao.status==200){
var returnStr=oBao.responseText;
document.write(returnStr);
}else{
document.write("未找到您输入的地址或服务器505错误!");
}
}
}
oBao.send(null);
}
getWebPage('http://www.google.cn');
</script>
保存这段代码到test.html,在本地直接用IE打开没问题,但将该段代码上传到服务器后,问题出现了--JS提示"没有权限"错误!!!这该如何解决呢?
下面思考一下:既然不能访问非同域的,只能访问同域的地址了,同域的动态文件怎么获取非同域网页内容呢?我们还是想到的AJAX,只不过这个AJAX是在服务器端执行.
大体思路是这样的:首先将URL用AJAX提交给自己站内的文件,例如getPage.asp---在getPage.asp再次通过服务器XMLHTTP来访问提交来的URL---将获取的内容返回给提交URL的页----显示内容
下面开始组织代码,首先是test.html文件
<script type="text/javascript">
function createobj() {
if (window.ActiveXObject) {
return new ActiveXObject("Microsoft.XMLHTTP");
}
else if (window.XMLHttpRequest) {
return new XMLHttpRequest();
}
}
function getWebPage(url) {
var oBao=createobj();
var my_url="getpage.asp?url="+escape(url);
oBao.open('get',my_url,false);
oBao.onreadystatechange=function(){
if(oBao.readyState==4){
if(oBao.status==200){
var returnStr=oBao.responseText;
document.write(returnStr);
}else{
document.write("未找到您输入的地址或服务器505错误!");
}
}
}
oBao.send(null);
}
getWebPage('http://www.google.cn');
</script>
再就是getpage.asp文件(注意:要以UTF-8格式保存本文件,防止乱码),如下:
<%
response.charset="UTF-8"
reg="\<meta.+ charset= {0,}([^\"" \>\/]*).+\/{0,1}\>"
'函数名:GetResStr
'作用:获取指定URL的HTML代码
'参数:URL-要获取的URL
function GetResStr(URL)
err.clear
dim ResBody,ResStr,PageCode,ReturnStr
Set Http=createobject("MiCROSOFT.XMLHTTP")
Http.open "GET",URL,False
Http.Send()
If Http.Readystate =4 Then
If Http.status=200 Then
ResStr=http.responseText
ResBody=http.responseBody
PageCode=GetCode(ResStr,reg)
ReturnStr=BytesToBstr(http.responseBody,PageCode)
GetResStr=ReturnStr
End If
End If
End Function
'函数名:BytesToBstr
'作用:转换二进制数据为字符
'参数:Body-二进制数据,Cset-文本编码方式
Function BytesToBstr(Body,Cset)
Dim Objstream
Set Objstream = CreateObject("adodb.stream")
objstream.Type = 1
objstream.Mode =3
objstream.Open
objstream.Write body
objstream.Position = 0
objstream.Type = 2
objstream.Charset =Cset
BytesToBstr = objstream.ReadText
objstream.Close
set objstream = nothing
End Function
'函数名:GetCode
'作用:转换二进制为字符
'参数:str-待查询字符串,regstr-正则表达式
Function GetCode(str,regstr)
Dim Reg,serStr
set Reg= new RegExp
Reg.IgnoreCase = True
Reg.MultiLine = True
Reg.Pattern =regstr
if Reg.test(str) then '若查询到匹配项
Set Cols = Reg.Execute(str)
serStr=Cols(0).SubMatches(0) '使用匹配到的第一个匹配项
else '否则给个默认值gb2312,有点省懒法,如果页面没给出编码格式,想知道确实有点麻烦
serStr="gb2312"
end if
GetCode=serStr
end function
dim url:url=request.querystring("url")
response.write GetResStr(URL)
%>
代码组织完毕,实验下,成功提取http://www.google.cn的内容!!!!!这样就可以解决"没有权限"的问题了。
其实,单纯一个getpage.asp一样能获取,不过不能像js那样动态的处理DOM。
还有一个问题,如果你用第一种方法访问http://www.baidu.com会出现乱码,因为baidu编码为GB2312,
而XMLHTTP返回的是UTF-8编码格式。用第二种方法就不会出现这样的问题了,只要定义了编码格式的站点就能正常返回信息(这里不能包括一些使用特别编码的站点)。
分享到:
相关推荐
### 解决AJAX中跨域访问出现“没有权限”的错误 在进行网页开发时,我们经常需要使用Ajax(Asynchronous JavaScript and XML)技术来实现页面的异步加载和交互功能。然而,在处理跨域请求时,经常会遇到一个让人...
在AJAX中遇到“没有权限”错误,可以通过以下几种方法解决: 1. JSONP(JSON with Padding):利用`<script>`标签的特性,绕过同源策略限制。通常需要服务器支持,因为需要在服务器端进行相应的处理,将JSON数据...
禁止访问非同域的网站,下面一个例子来访问http://www.google.cn, [removed] function createobj() { if (window.ActiveXObject) { return new ActiveXObject(“Microsoft.XMLHTTP”); } else if (window....
AJAX跨域问题的出现是由于浏览器的安全机制,旨在防止恶意网站通过脚本访问其他网站的数据,保护用户隐私。但是,在某些场景下,比如前后端分离的应用、API接口调用等,跨域请求是必要的。针对这一需求,有多种解决...
- 如果你的接口需要权限校验,比如需要在header中携带token,浏览器的预检请求会导致500错误。在这种情况下,你需要在Spring Boot的全局配置中允许这些自定义headers,同时处理OPTIONS请求。在上面的`CorsConfig`...
本文将详细讨论Ajax跨域问题及其两种常见解决方案:JSONP和CORS。 首先,我们来明确什么是跨域。当浏览器尝试从一个源(协议+域名+端口)向另一个源发送请求时,如果两个源不匹配,就会遇到跨域问题。这包括但不...
然而,在实际应用中,我们可能会遇到各种错误情况,这些错误可能是由于语法错误、网络问题、服务器端问题或是资源权限问题导致的。标题提到的“ajax错误代码”就是指在使用AJAX时遇到的问题。 首先,让我们深入了解...
在IE9以下的版本中,如果遇到ajax跨域请求数据失败,浏览器可能会返回错误,例如“notransport”或“没有权限”。这类错误提示了请求无法成功发送或服务器不允许跨域访问。 要解决IE9以下版本浏览器中的跨域问题,...
总之,解决ASP.NET中的错误需要对整个应用程序生命周期有深入理解,包括代码编写、编译、运行、部署以及维护。开发者应掌握基本的调试技巧,了解IIS和.NET Framework的工作原理,以及如何有效地管理和优化应用程序的...
12. **文件上传错误**:文件大小限制、文件类型不匹配等问题会在上传过程中出现。 13. **服务器配置错误**:比如Apache或Nginx的配置文件错误,可能导致服务器无法启动或响应异常。 14. **内存溢出**:长时间运行...
4. **跨域问题**:讨论Ajax请求时可能出现的跨域限制,以及CORS(跨源资源共享)的解决方案。 5. **JSONP(JSON with Padding)**:介绍在同源策略限制下的另一种跨域数据交互方式。 6. **AJAX与DOM**:解释如何使用...
8. **错误处理**:在前端和后端,都需要处理可能出现的错误,例如网络问题、文件过大、格式不支持等。错误处理可以通过监听`error`事件或捕获Promise的拒绝来实现。 通过以上步骤,我们可以实现一个基本的Ajax批量...
在Spring Security配置中,我们需要确保Ajax请求不会因为没有适当的HTTP头而被拒绝。通常,这可以通过配置`HttpSecurity`对象来实现,添加对X-Requested-With头的支持,这是一个常见的标记Ajax请求的头信息。 ```...
首先,我们要理解为什么会出现“jQuery没有权限”的错误。在Web开发中,出于安全考虑,浏览器实施了同源策略(Same-origin policy),这意味着JavaScript只能访问与当前页面同源(协议、域名、端口相同)的资源。...
4. **权限问题**:跨域请求未开启CORS(Cross-Origin Resource Sharing),或者服务器端未允许特定的源进行访问。 5. **服务器端错误**:服务器端代码出错,例如PHP、Java等后端语言的异常处理不当,导致返回非200...
当一个Web页面试图通过AJAX发起一个跨域请求时,如果服务器端没有明确允许这种跨域请求,浏览器就会抛出SecurityError。为了解决这个问题,可以在服务器端设置适当的CORS头部信息,允许跨域请求。例如,在Node.js...
这个过滤器可以拦截HTTP请求,并根据配置规则决定是否允许跨域访问。在Geoserver中配置CORS Filter,可以允许来自特定网站或者所有网站的跨域请求,这对于前端GIS应用的开发至关重要,特别是使用Ajax技术进行异步...
4. **错误处理**:在AJAX请求过程中,可能出现网络问题或服务器错误。一个好的工具包会提供优雅的错误处理机制,帮助开发者更好地应对这些问题。 5. **请求方法与参数**:工具包应支持GET、POST等常见的HTTP方法,...
- 考虑跨域问题,确保Ajax请求遵循同源策略或配置服务器允许跨域。 - 数据安全:防止恶意用户通过Ajax接口获取敏感信息,应实施适当的权限验证。 - 用户体验:显示加载动画,提升用户体验,告知用户请求正在进行。 -...