php禁止ip訪問
⑴ 如何用php實現IP限制
<?php
error_reporting(7);
session_start();
// 發送字元頭信息
if ($headercharset)
header("Content-Type:text/html; charset=gb2312");
// 載入公共文件
require_once("config.php");
require_once("global.php");
require_once("db_mysql.php");
/***************** 進行客戶端能否訪問本網站校驗 ************/
// 獲取客戶端IP
if(getenv('HTTP_CLIENT_IP')) {
$client_ip = getenv('HTTP_CLIENT_IP');
} elseif(getenv('HTTP_X_FORWARDED_FOR')) {
$client_ip = getenv('HTTP_X_FORWARDED_FOR');
} elseif(getenv('REMOTE_ADDR')) {
$client_ip = getenv('REMOTE_ADDR');
} else {
$client_ip = $HTTP_SERVER_VARS['REMOTE_ADDR'];
}
// 分解客戶端IP
$cip = explode(".", $client_ip);
// 連接資料庫
$db = new DB_Sql();
$err = $db->connect();
/* 限制遠程IP訪問, PS: 這段代碼真暈,呵呵,用了8個if, -_-# */
// 從資料庫中提取存儲的要限制的IP地址
$query_str = "SELECT limit_ip FROM us_limitip";
$db->query($query_str);
// 把結果循環提取,一個個進行校驗
while ($db->next_record())
{
$limit_ip = $db->f("limit_ip");
$lip = explode(".", $limit_ip);
// 如果限制IP的第一個是*或者是0的話就跳到錯誤頁
if (($lip[0]=='*') || ($lip[0]=='0'))
header("Location:../error.php?errid=300");
// 如果剛好客戶端IP等於我們限制IP就跳到錯誤頁
if ($client_ip==$limit_ip)
header("Location:../error.php?errid=300");
// 如果第一組IP一致進行第二組IP的匹配
if ($cip[0] == $lip[0])
{
// 如果第二組限制IP是*就跳到錯誤頁
if ($lip[1]=='*')
header("Location:../error.php?errid=300");
// 第二組IP匹配就進行第三組IP匹配
if ($cip[1]==$lip[1])
{
// 如果第三組限制字元是*就跳到錯誤頁
if ($lip[2]=='*')
header("Location:../error.php?errid=300");
// 如果第三組IP匹配就跳到第三組校驗
if ($cip[2]==$lip[2])
{
// 如果第四組限制IP是*或0就跳到錯誤頁
if (($lip[3]=='*') || ($lip[3]=='0'))
header("Location:../error.php?errid=300");
}
}
}
}
// 釋放資料庫查詢結果
$db->free();
/****************** IP校驗結束 ******************/
?>
⑵ 如何使用PHP實現自動封鎖IP地址
1、登錄的時候獲取真實的IP地址,失敗一次就記錄在一個txt文本里。
2、然後再判斷該IP錯誤的次數統計,只要去TXT裡面找到,如果超過3個同樣的IP,那就封鎖他的IP,禁止登陸。
3、在上面的程序中加入一個清楚txt,例如24小時自動清除一下。
⑶ 限制ip地址段訪問的php代碼
<?php
$userip = $_SERVER['REMOTE_ADDR']; //獲得用戶ip
$userips = explode(".", $userip);//把獲得的ip切開成數組
if(($userips[0]<=195 && $userips[0]>=195)&&($userips[1]<=163 && $userips[1]>=163)&&($userips[2]<=079 && $userips[2]>=072)&&($userips[3]<=255 && $userips[3]>=000)){
echo "您的ip不符!";
exit;
}else{
echo "通過驗證!";
}
?>
我的思路就是這樣的
獲得用戶的IP 用"."分割成數組
再將 限制IP斷 分別用"."分割成數組
然後判斷用戶IP是否在這個IP斷內(分別判斷四個元素是否在這個范圍里)
……
下面是藍色理想里找到的一個供你參考
——————————————————
<?php
class IP{ //獲取客戶IP地址
function getIpAdr(&$ ip){
$ ip1=getenv("HTTP_X_FORWARDED_FOR");
$ ip2=getenv("HTTP_CLIENT_IP");
$ ip3=getenv("REMOTE_ADDR");
if($ ip1&&$ ip1!='unknow')
$ ip=$ ip1;
else if($ ip2&&$ ip2!='unknow')
$ ip=$ ip2;
else if($ ip3&&$ ip3!='unknow')
$ ip=$ ip3;
else
$ ip='127.0.0.1';
}
}
function get_netip($ myip){ //只留客戶IP地址的前三位
$ temp=explode(".",$ myip);
$ netip.=$ temp[0];
$ netip.=".";
$ netip.=$ temp[1];
$ netip.=".";
$ netip.=$ temp[2];
return $ netip;
}
$ filename="test.ini"; //定義操作文件
$ ip_lib=file($ filename); //讀取文件數據到數組中
$ allow=0;
$ IP=new IP;
$ thisip="";
$ IP->getIpAdr(&$ thisip);
$ thenetip=get_netip($ thisip);
for($ i=0;$ i<count($ ip_lib);$ i++){
if(ereg($ thenetip,$ ip_lib[$ i])){
$ allow=1;
break;
}
}
if ($ allow==1)
{
echo "驗證通過";
}
else {
echo "<script>location.href='Error.php';</script>";
}
?>
⑷ 如何用php實現IP限制
<?php
//可訪問IP存放在文件aip.txt裡面
$ip=$_SERVER['REMOTE_ADDR'];
$ok=0;
foreach (preg_split('/\s+/',file_get_contents('aip.txt')) as $aip)
if ($ip==$aip) $ok=1;
if ($ok==0){
echo '未授權';
exit;
}
//後面是正常的代碼
?>
⑸ php怎麼禁止某ip或ip地址段訪問
//禁用單個ip如下:
<?php
//禁用ip地址
$ip=$_SERVER["REMOTE_ADDR"];
$ban=file_get_contents("ban.dat");
if(stripos($ban,$ip))
{
die("YourIPAddressis:$ip,you'reforbidentoviewthispage!");
}
echo"YourIPAddressis:$ip,hello!";
?>
//禁用ip段如下:
<?php
//禁用ip地址
$ip=$_SERVER["REMOTE_ADDR"];
while($ip[count($ip-1)]!='.')$ip=substr($ip,1,-1);//整理出ip段
$ban=file_get_contents("ban.dat");
if(stripos($ban,$ip))
{
die("U'reforbidentoviewthispage!");
}
echo"Hello!";
?>
⑹ PHPCMS如何禁止IP訪問網站
禁止IP其實沒什麼用。如果用戶是撥號上網。每次重啟一下貓和路由。IP就變了。當然這種在一定程度上是可以起作用的。最好是IP和賬號一起設置成禁止。IP禁止訪問的方法。獲取用戶請求包頭部。頭部會包含對方的IP。獲取它並判斷。具體怎麼獲取頭部里信息。網路一下。很多。
⑺ PHP中如何阻止某個IP頻繁的發請求
兩個方法
一個是系統級的,也就是在系統里通過軟體將這個ip屏蔽掉,這需要你有伺服器的管理許可權
第二個方法就是應用級的了
在你的程序里,加上ip訪問模塊,添加黑名單即可。
⑻ PHP限制IP
判斷客戶端IP:
$_SERVER['REMOTE_ADDR']。
如果IP在允許的范圍內,繼續執行網頁;
如果IP不再允許(或者禁止)的范圍內,退出:
exit();
應該會明白的吧?
⑼ 求一段PHP限制IP及IP段訪問的代碼,拜託了。。
正確代碼
function check_ip(){
$ALLOWED_IP=array('192.168.2.*','127.0.0.1','192.168.2.49');
$IP=getIP();
$check_ip_arr= explode('.',$IP);//要檢測的ip拆分成數組
#限制IP
if(!in_array($IP,$ALLOWED_IP)) {
foreach ($ALLOWED_IP as $val){
if(strpos($val,'*')!==false){//發現有*號替代符
$arr=array();//
$arr=explode('.', $val);
$bl=true;//用於記錄循環檢測中是否有匹配成功的
for($i=0;$i<4;$i++){
if($arr[$i]!='*'){//不等於* 就要進來檢測,如果為*符號替代符就不檢查
if($arr[$i]!=$check_ip_arr[$i]){
$bl=false;
break;//終止檢查本個ip 繼續檢查下一個ip
⑽ 如何用php實現IP訪問限制
function nTabs(thisObj,Num){
if(thisObj.className == "active")return;
var tabObj = thisObj.parentNode.id;
var tabList = document.getElementById(tabObj).getElementsByTagName("li");
for(i=0; i <tabList.length; i++)
{