Перейти к контенту
  • 0

IP защита админки


alrond

Вопрос

Рекомендуемые сообщения

  • 0

поточнее:

открываем admin.php:

сразу после

<?php

пишем

// массив допускаемых (если делать без бд)
$access_ips = array('127.0.0.1', '127.0.0.2');
// берем ip клиента
$ip = $_SERVER["REMOTE_ADDR"];
// ищем в массиве
if (!in_array($ip, $access_ips)) echo "Нет доступа";
else {
// переложить весь базовый код admin.php
}

 

для масок ищем вхождения точек...

$access_ips = array('127.0.0.1', '127.0.0.2');
$ip = $_SERVER['REMOTE_ADDR']; 
echo "Ваш адрес: ".$ip."<br>\n";
$ip = explode('.', $ip);

$access = TRUE;
for ($k = 0; $k < count($access_ips); $k++) {
 $access_ip = explode('.', $access_ips[$k]);
 for ($i = 0; $i < count($access_ip); $i++) {
  if ($ip[$i] != $access_ip[$i]) {
   $access = FALSE;
   break;
  }
  else $access = TRUE;
 }
}

if (!$access) echo "Нет доступа";
else echo "Есть доступ";

Ссылка на комментарий
Поделиться на других сайтах

  • 0

Po logike ne rabotaet :D

 

 $access_ip = explode('.', $access_ips[$k]);
 for ($i = 0; $i < count($access_ip); $i++) {
  if ($ip[$i] != $access_ip[$i]) {
   $access = FALSE;
   break;
  }
  else $access = TRUE;
 }

 

Naprimer imeem svoj IP=11.22.33.44

i v baze dostupa est' IP=11.22.99.88

 

togda logika raboty programmy:

 

if ($ip[0] != $access_ip[0]) { 11=11

$access = FALSE;

break;

 

if ($ip[1] != $access_ip[1]) { 22=22

$access = FALSE;

break;

 

if ($ip[3] != $access_ip[3]) { 33=99

$access = FALSE;

break;

 

STOP

 

a dolzhen perebirat' adresa naprimer

11.22.0-255.0-255

Добавлено в [mergetime]1097066051[/mergetime]

Vsem spasibo...

cherez .htaccess vse ochen' prosto i podsetki tozhe

 

<Files admin.php>

deny from all

allow from XX.XX.XX YY.YY

</Files>

Ссылка на комментарий
Поделиться на других сайтах

  • 0

Не так...

в базе ип должен иметь форму: "11.22" :D для подсети, в противном случае случае вы ищите ip, а не подсеть ;)

Добавлено в [mergetime]1097066435[/mergetime]

напоследок, моя функция для определения истинного ip, с использованием прокси...

 

function realip() {
 if ($_SERVER) {
  if ($_SERVER["HTTP_X_FORWARDED_FOR"]) $realip = $_SERVER["HTTP_X_FORWARDED_FOR"];
  elseif ($_SERVER["HTTP_CLIENT_IP"]) $realip = $_SERVER["HTTP_CLIENT_IP"];
  else $realip = $_SERVER["REMOTE_ADDR"];
 }
 else {
  if (getenv('HTTP_X_FORWARDED_FOR')) $realip = getenv('HTTP_X_FORWARDED_FOR');
  elseif (getenv('HTTP_CLIENT_IP')) $realip = getenv('HTTP_CLIENT_IP');
  else $realip = getenv('REMOTE_ADDR');
 }
 if ($realip == "") $realip = $_SERVER["SERVER_ADDR"];
 return $realip;
}

Ссылка на комментарий
Поделиться на других сайтах

  • 0
А что будет выдаваться показываться у тех, кто будет заходить с других айпи!?

Если сделать так, как описал пользователь Cepera, то будет появляться надпись: «Нет доступа» (надпись будет отображаться без кавычек).

Ссылка на комментарий
Поделиться на других сайтах

Присоединиться к обсуждению

Вы можете ответить сейчас, а зарегистрироваться позже. Если у вас уже есть аккаунт, войдите, чтобы ответить от своего имени.

Гость
Unfortunately, your content contains terms that we do not allow. Please edit your content to remove the highlighted words below.
Ответить на вопрос...

×   Вы вставили отформатированный текст.   Удалить форматирование

  Допустимо не более 75 смайлов.

×   Ваша ссылка была автоматически заменена на медиа-контент.   Отображать как ссылку

×   Ваши публикации восстановлены.   Очистить редактор

×   Вы не можете вставить изображения напрямую. Загрузите или вставьте изображения по ссылке.

Зарузка...
×
×
  • Создать...

Важная информация

Находясь на нашем сайте, вы соглашаетесь на использование файлов cookie, а также с нашим положением о конфиденциальности Политика конфиденциальности и пользовательским соглашением Условия использования.