<script type="text/javascript"> function createobj() { if (window.ActiveXObject) { return new ActiveXObject("Microsoft.XMLHTTP"); } else " /> 欧美天堂影院,不卡视频观看,伊人久久成人

色尼玛亚洲综合影院,亚洲3atv精品一区二区三区,麻豆freexxxx性91精品,欧美在线91

解決AJAX中跨域訪問出現(xiàn)'沒有權限'的錯誤

禁止訪問非同域的網(wǎng)站,下面一個例子來訪問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打開沒問題,但將該段代碼上傳到服務器后,問題出現(xiàn)了--JS提示"沒有權限"錯誤!!!這該如何解決呢?
下面思考一下:既然不能訪問非同域的,只能訪問同域的地址了,同域的動態(tài)文件怎么獲取非同域網(wǎng)頁內(nèi)容呢?我們還是想到的AJAX,只不過這個AJAX是在服務器端執(zhí)行.
大體思路是這樣的:首先將URL用AJAX提交給自己站內(nèi)的文件,例如getPage.ASP---在getPage.ASP再次通過服務器XMLHTTP來訪問提交來的URL---將獲取的內(nèi)容返回給提交URL的頁----顯示內(nèi)容
下面開始組織代碼,首先是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}/>"
'函數(shù)名:GetResStr
'作用:獲取指定URL的HTML代碼
'參數(shù):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

'函數(shù)名:BytesToBstr
'作用:轉(zhuǎn)換二進制數(shù)據(jù)為字符
'參數(shù):Body-二進制數(shù)據(jù),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

'函數(shù)名:GetCode
'作用:轉(zhuǎn)換二進制為字符
'參數(shù):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的內(nèi)容!!!!!這樣就可以解決"沒有權限"的問題了。
其實,單純一個getpage.ASP一樣能獲取,不過不能像js那樣動態(tài)的處理DOM。
還有一個問題,如果你用第一種方法訪問http://www.baidu.com會出現(xiàn)亂碼,因為baidu編碼為GB2312,
而XMLHTTP返回的是UTF-8編碼格式。用第二種方法就不會出現(xiàn)這樣的問題了,只要定義了編碼格式的站點就能正常返回信息(這里不能包括一些使用特別編碼的站點)。

JavaScript技術解決AJAX中跨域訪問出現(xiàn)'沒有權限'的錯誤,轉(zhuǎn)載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯(lián)系我們修改或刪除,多謝。

主站蜘蛛池模板: 新营市| 庆元县| 平凉市| 晋中市| 同德县| 仁化县| 华坪县| 北票市| 清流县| 松原市| 宁海县| 庆云县| 雷波县| 金寨县| 新绛县| 饶平县| 唐河县| 阿克陶县| 宁远县| 扎囊县| 宣城市| 富锦市| 房山区| 肃宁县| 佛山市| 资阳市| 盐边县| 阳原县| 凉城县| 南澳县| 长治县| 葵青区| 桂阳县| 金湖县| 西吉县| 上栗县| 防城港市| 夏邑县| 佛坪县| 永仁县| 大英县|