国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > ASP > 正文

如何解決AJAX中跨域訪問出現'沒有權限'的錯誤

2024-05-04 11:07:29
字體:
來源:轉載
供稿:網友
很多人在使用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編碼格式。用第二種方法就不會出現這樣的問題了,只要定義了編碼格式的站點就能正常返回信息(這里不能包括一些使用特別編碼的站點)。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 水富县| 临海市| 巩留县| 桦南县| 吉安市| 三江| 邹城市| 济南市| 太康县| 库伦旗| 忻城县| 隆回县| 澄迈县| 南丰县| 东源县| 九江市| 苏尼特左旗| 唐山市| 舞阳县| 玉田县| 四平市| 澎湖县| 宁陵县| 山丹县| 太和县| 洪雅县| 山东| 陆川县| 东莞市| 兖州市| 兴海县| 甘南县| 蓬莱市| 伊春市| 黄平县| 正镶白旗| 彭州市| 舞阳县| 竹山县| 石城县| 湘潭市|