Большой архив статей, книг, документации по программированию, вебдизайну, компьютерной графике, сетям, операционным системам и многому другому
 
<Добавить в Избранное>    <Сделать стартовой>    <Реклама на сайте>    <Контакты>
  Главная Документация Новости ИТ Программы Книги Games   Обои   Экспорт RSS E-Books
 
Поиск по сайту

TOP-10 программ
Symantec Norton Ghost 9.0
Partition Magic 8.0.2 Pro
Xilisoft 3GP Video Converter v3.1.7.0616b
Norton AntiVirus 2005
Xilisoft 3GP Video Converter v2.1.52.831b
Антивирус Касперского Personal 5.0.303 beta 2
RAR Password Cracker 4.12
ABBYY PDF Transformer v1.00.820
MP3 To Ringtone Gold v3.02
Mobtime Cell Phone Manager v5.3.1
 
Наши сервисы
Рассылка новостей. Подпишитесь на рассылку сейчас и вы всегда будете в курсе последних событий в мире информационных технологий.
Новостные информеры. Поставьте наши информеры к себе и у вас на сайте появится дополнительный постоянно обновляемый раздел.
Добавление статей. Если вы являетесь автором статьи или обзора на тему ИТ присылайте материал нам, мы с удовольствием опубликуем его у себя на сайте.
 
 

   Интернет технологии -> PHP -> Как можно проверить какой IP, и запретить доступ к странице?


Как можно проверить какой IP, и запретить доступ к странице, или переслать на другую?

if(getenv("HTTP_CLIENT_IP")) {
$ip = getenv("HTTP_CLIENT_IP");
} elseif(getenv("HTTP_X_FORWARDED_FOR")) {
$ip = getenv("HTTP_X_FORWARDED_FOR");
} else {
$ip = getenv("REMOTE_ADDR");
}
ну и проверяй потом, соответствует, или нет
__________________
Евгений aka Razor, http://eugeny.com

пробовал, работает. Теперь, я еще и записываю в файл IP
  всех кто в гостевой, так что уже не должно быть проблем .

HTTP_CLIENT_IP - этой переменной сервер пытается определить адрес usera на   прямую исключая пркси...

сорри что так поздно..... но вы в курсе что будет если "HTTP_CLIENT_IP"   передать в качестве GET или POST перематров?

Во-первых это зависит от порядка EGPCS
  Во-вторых в приведенном примере HTTP_CLIENT_IP берется через getenv() то есть   GET и POST на него не влияют.

И еще по поводу общей темы. У меня был случай когда код

if(getenv("HTTP_CLIENT_IP")) {
  $ip = getenv("HTTP_CLIENT_IP");
  } elseif(getenv("HTTP_X_FORWARDED_FOR")) {
  $ip = getenv("HTTP_X_FORWARDED_FOR");
  } else {
  $ip = getenv("REMOTE_ADDR");
  }

неработал. Проблема была в том что человек сидел за каким-то нестандартным   прокси и
  он определял HTTP_X_FORWARDED_FOR как строку "undefine".
  Поскольку это была именно строка if(getenv("HTTP_X_FORWARDED_FOR"))   возвращало true, ну а дальше все понятно.
  Поэтому я еще делал проверку чтобы было соответствие формату ip DDD.DDD.DDD.DDD

Я на свое м сайте использую простую систему из двух файлов
  1. Ban.php ( прикреплен к header.php в самом начале, т.е. открывается В Е З   Д Е первым.

<?php
  $ban=getenv("REMOTE_ADDR");
  if ($ban=="ip забаненного ") {
  include "banau.php";/ если твой ip - забанен , то вставлаю файл с   авторизацией.
  }
  ?>

2. banau.php самая обыкновенная авторизация. Так что этот подлец которого Я   забанил ко мне не ходит.

Еще можно было бы ему в куки записывать при входе на страничку которая выдаеться   при трех неудачных попытках авторизоваться <?
  setcookie ("banned", "yes"); ?>

_________________
  http://www.alesh.ru

alesh вроде бы всё хорошо
  но если человек поматюгался у него порвалась связь и он заново зашел ему назначился   другой ИП и всё заново
  а потом хороший человек подключился и ему присвоили ИП подлеца что делать?
  Тут ещё требуется протоколировать дату и баннить спамера на 2-24 не более

Ну тогда нада банить по ип И по кукам.
  что-то типа

<?
  $ban=getenv("REMOTE_ADDR");
  setcookie ("banned", "yes");
  setcookie ("ip", "$ban"); ?>
  if (@$HTTP_COOKIE_VARS["banned"] == '' ) { // смотри на здоровье!   
  ...
  }
  else {
  include "banau.php";
  }
  ?>


  Ну и добавить сюда еще и второй цикл для кука $ip

И тогда будет двойная проверка.
  А по другому никак. Ну можно еще надеятся, что все недоброжелатели сидят на   выделенках с прямыми айпишниками
  А, ну и еще прикрепить сюда проверку по ip! если у него он постоянный все таки

И того в итоге получиться......

<?php
  $ban=getenv("REMOTE_ADDR");
  if ($ban=="127.0.0.1" & $HTTP_COOKIE_VARS["banned"]   =="yes" $) {
  include "banau.php";
  setcookie ("banned", "yes");
  setcookie ("ip", "$ban");
  }
  ?>

сидит за анонимной проскеё и суёт ей вшивые адреса то отключая всю проскю появляется   возможность заблокироват большую корпоративную сеть

И это действительно так, то
  1. Надо просто стереть его сообщение в гостевой
  2. Забанить его и написать по всем вопросам обращайтесь banned@host.ru
  и Сидеть себе спокойно Кому надо напишет
  __________________
  http://www.alesh.ru

Источник: www.articles.org.ru

Ссылки по теме
Разработка собственных листов рассылки
Безопасность PHP+MYSQL+Apache
Чтение почты через Web-интерфейс
Полезные скрипты на PHP
PHP и формы
Почтовые функции в РНР
Отправка электронной почты с помощью PHP
 

Компьютерная документация от А до Я - Главная

 
Популярные книги

Photoshop CS2 для пользователя

Подробнее

Общая информатика. Универсальный курс

Подробнее

Ремонт и обслуживание компьютера дома

Подробнее


 
Новости ИТ
04.12.2008  В Windows 7 запуск приложений Direct3D 10/10.1 будет возможен на CPU
04.12.2008  eGo BlackBelt и Encrypt - пара новых портативных HDD Iomega с зашитой данных
04.12.2008  A-DATA выпускает двух- и трёхканальные наборы памяти DDR3-1800+ в серии XPG Plus
04.12.2008  MOTOROKR EM35
04.12.2008  Шведский производитель ковриков для мышей выпустил игровую гарнитуру
04.12.2008  eGo BlackBelt и Encrypt - пара новых портативных HDD Iomega с защитой данных
04.12.2008  Вышла вторая бета-версия Windows Vista SP2
04.12.2008  Внешний SSD-накопитель с поддержкой eSATA и USB
04.12.2008  Флэшка OCZ со встроенным кард-ридером
04.12.2008  Весрия «ПАУ» 1.8.2 будет содержать новый функционал
04.12.2008  Компания «Русские Информационные Технологии» подготовила бета-версию программы «Печать конвертов!»
04.12.2008  Телефон премиум-класса с двумя SIM-картами
04.12.2008  High-end десктопы Asus Eee Box
04.12.2008  Видеокарта NVIDIA Quadro FX 4800 для профессионалов
04.12.2008  Экстремальные внешние HDD от Iomega
04.12.2008  MSI EX300 - 13.3 дюйма для развлечения
04.12.2008  SATA 3.0 появится в следующем году
04.12.2008  Mini-ITX-плата Zotac на основе логики NVIDIA и с поддержкой Wi-Fi
04.12.2008  Корпус NZXT Zero 2: улучшенное охлаждение и строгий дизайн
04.12.2008  Конвертеры: Xilisoft Video Converter v.5.1.7.1128
 
Полезно

 
Copyright © CompDoc.Ru
При цитировании и перепечатке ссылка на www.compdoc.ru обязательна. Карта сайта.
 
Rambler's Top100