主頁(yè) > 知識(shí)庫(kù) > php獲取referer防非法訪問(wèn)

php獲取referer防非法訪問(wèn)

熱門標(biāo)簽:上海400客服電話怎么申請(qǐng) 溫州外呼系統(tǒng)招商 凱立德地鐵站地圖標(biāo)注 滄州電銷外呼系統(tǒng)價(jià)格 手機(jī)外呼系統(tǒng)什么原理 天津電銷外呼系統(tǒng)違法嗎 銀行信貸電話機(jī)器人 400電話個(gè)人能不能辦理 合肥ai電銷機(jī)器人費(fèi)用

面是我下載頁(yè)面down.php 的php代碼 現(xiàn)在我發(fā)現(xiàn),用迅雷,谷歌瀏覽器直接打開,就能輸出下載文件,一點(diǎn)不起防盜鏈作用。 現(xiàn)在我想,只允許在我自己站上連接過(guò)來(lái)的可以直接使用,別的的站過(guò)來(lái)的,和直接輸入這個(gè)地址的,跳轉(zhuǎn)到copy.htm頁(yè)上去。

PHP中的 $_SERVER["HTTP_REFERER"] 預(yù)定義服務(wù)器變量可以判斷來(lái)路。
$_SESSION['HTTP_REFERER']可以獲取當(dāng)前鏈接的上一個(gè)連接的來(lái)源地址,即鏈接到當(dāng)前頁(yè)面的前一頁(yè)面的 URL 地址。
一般用于判斷瀏覽者是從哪里點(diǎn)擊鏈接跳到本頁(yè)面的,即所說(shuō)的來(lái)路,還可以通過(guò)判斷來(lái)路來(lái)防止盜鏈。
例如:

?php

$url_array = parse_url($_SESSION['HTTP_REFERER']); 
//如果頁(yè)面的域名不是服務(wù)器域名,就連接到登陸窗口 
if($_SERVER['HTTP_HOST'] != $url_array["host"]) { 
header("location: login.php"); 
exit; 
} 

?>

相關(guān)代碼

近期有個(gè)項(xiàng)目需要用到防止用戶非法訪問(wèn)某json頁(yè)面,基礎(chǔ)解決方法就是判斷來(lái)路來(lái)限制非調(diào)用訪問(wèn):

$_SERVER[‘HTTP_REFERER']:來(lái)路鏈接,可能帶尾巴(如:http://www.httple.net/iwork/20.html),可以通過(guò)php內(nèi)置函數(shù)parse_url()來(lái)獲取到當(dāng)前網(wǎng)址(www.httple.net),即:

$refererUrl = parse_url($_SERVER[‘HTTP_REFERER']);

$host = $refererUrl[‘host'];

$host的值即為來(lái)路的網(wǎng)址(www.httple.net)。

獲取到了來(lái)路的網(wǎng)址之后,我們就可以通過(guò)這個(gè)網(wǎng)址來(lái)限制訪問(wèn)該頁(yè)面的權(quán)限了。代碼如下:

if(!isset($_SERVER[‘HTTP_REFERER']) || $referurl[‘host'] !=”www.httple.net”) {
header(“l(fā)ocation: /”); //如果沒(méi)有來(lái)路,或者來(lái)路不是本站,跳轉(zhuǎn)到首頁(yè)。
exit;
}

把這行代碼放到j(luò)son數(shù)據(jù)頁(yè)面的最上方,就能簡(jiǎn)單解決該問(wèn)題。

該處理方法的缺陷:可通過(guò)偽造來(lái)路獲取到該頁(yè)面的正常數(shù)據(jù)。

相關(guān)代碼

獲取來(lái)路Url 的方法,主要用到服務(wù)器變量中HTTP_REFERER函數(shù)的使用,代碼貼上:

function get_referer(){   
$url = $_SERVER["HTTP_REFERER"]; //獲取完整的來(lái)路URL   
$str = str_replace("http://","",$url); //去掉http://   
$strdomain = explode("/",$str); // 以“/”分開成數(shù)組   
$domain = $strdomain[0]; //取第一個(gè)“/”以前的字符  
return $domain;  
}   
 
//對(duì)于百度、谷歌搜索引擎來(lái)路判斷   
function get_seo(){  
$s = 0;   
if(strstr(get_referer(),'baidu.com')){   
$s = 1;   
}   
else if(strstr(get_referer(),'google.com.hk')){   
$s = 1;   
}   
return $se;    
}

php網(wǎng)站 獲取來(lái)路Url 的方法,主要用到服務(wù)器變量中HTTP_REFERER函數(shù)的使用,代碼貼上:

function get_referer(){
$url = $_SERVER["HTTP_REFERER"]; //獲取完整的來(lái)路URL
$str = str_replace(“http://”,””,$url); //去掉http://
$strdomain = explode(“/”,$str); // 以“/”分開成數(shù)組
$domain = $strdomain[0]; //取第一個(gè)“/”以前的字符
return $domain;
}
 
//對(duì)于百度、谷歌搜索引擎來(lái)路判斷
function get_seo(){
$s = 0;
if(strstr(get_referer(),'baidu.com')){
$s = 1;
}
else if(strstr(get_referer(),'google.com.hk')){
$s = 1;
}
return $se;
}

在處理一個(gè)表單的時(shí)候,不得不考慮到用戶靜態(tài)提交的可能,discuz 已經(jīng)根據(jù)formhash來(lái)判斷

這里我用另一種方式來(lái)處理 判斷頁(yè)面來(lái)路,當(dāng)然這種方法也能夠被偽造HTTP_REFERER來(lái)路

第二部分是解決了 PHP中header('location:  跳轉(zhuǎn)頁(yè)面后 下一頁(yè)無(wú)法獲取HTTP_REFERER,這里只能在頁(yè)面加個(gè)鏈接 然后用js 模擬點(diǎn)擊鏈接,這樣下一頁(yè)肯定會(huì)收到HTTP_REFERER的。Keyword:document.getElementById('gourl').click();

到此這篇關(guān)于php獲取referer防非法訪問(wèn)的文章就介紹到這了,更多相關(guān)php放置非法訪問(wèn)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:
  • 詳解php偽造Referer請(qǐng)求反盜鏈資源
  • php 偽造HTTP_REFERER頁(yè)面URL來(lái)源的三種方法
  • PHP偽造來(lái)源HTTP_REFERER的方法實(shí)例詳解
  • php中HTTP_REFERER函數(shù)用法實(shí)例
  • 使用php偽造referer的方法 利用referer防止圖片盜鏈
  • PHP利用REFERER根居訪問(wèn)來(lái)地址進(jìn)行頁(yè)面跳轉(zhuǎn)
  • php中XMLHttpRequest(Ajax)不能設(shè)置自定義的Referer的解決方法
  • php中突破基于HTTP_REFERER的防盜鏈措施(stream_context_create)

標(biāo)簽:洛陽(yáng) 七臺(tái)河 金華 白城 怒江 酒泉 溫州 赤峰

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《php獲取referer防非法訪問(wèn)》,本文關(guān)鍵詞  php,獲取,referer,防,非法,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《php獲取referer防非法訪問(wèn)》相關(guān)的同類信息!
  • 本頁(yè)收集關(guān)于php獲取referer防非法訪問(wèn)的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章