Я пытаюсь все отрицать и допускаю только один IP. Но я хотел бы, чтобы следующий htaccess работал для этого единственного IP. Я не нахожу способ, чтобы оба работали: запретить все и разрешить только один плюс следующие опции:
<IfModule mod_rewrite.c>
RewriteEngine On
RewriteBase /
#Removes access to the system folder by users.
#Additionally this will allow you to create a System.php controller,
#previously this would not have been possible.
#'system' can be replaced if you have renamed your system folder.
RewriteCond %{REQUEST_URI} ^system.*
RewriteRule ^(.*)$ /index.php?/$1 [L]
#When your application folder isn't in the system folder
#This snippet prevents user access to the application folder
#Submitted by: Fabdrol
#Rename 'application' to your applications folder name.
RewriteCond %{REQUEST_URI} ^application.*
RewriteRule ^(.*)$ /index.php?/$1 [L]
#Checks to see if the user is attempting to access a valid file,
#such as an image or css document, if this isn't true it sends the
#request to index.php
RewriteCond %{REQUEST_FILENAME} !-f
RewriteCond %{REQUEST_FILENAME} !-d
RewriteRule ^(.*)$ index.php?/$1 [L]
</IfModule>
<IfModule !mod_rewrite.c>
# If we don't have mod_rewrite installed, all 404's
# can be sent to index.php, and everything works as normal.
# Submitted by: ElliotHaughin
ErrorDocument 404 /index.php
</IfModule>
Есть ли способ сделать эту работу?
allow from yourIPv6
Я знаю, что на этот вопрос уже есть принятый ответ, но документация Apache гласит:
Итак, более перспективный ответ будет:
Надеюсь, я помог предотвратить превращение этой страницы в один из этих «устаревших учебников». :)
источник
Require ip
несколько строк, чтобы сделать их более читабельными для пользователя, или все IP-адреса должны быть в одной строке?Это можно улучшить с помощью директивы, разработанной для этой задачи.
Где 111.222.333.444 - ваш статический IP-адрес.
При использовании директивы Order Allow, Deny запросы должны совпадать с Allow или Deny, если ни один из них не выполняется, запрос отклоняется.
http://httpd.apache.org/docs/2.2/mod/mod_authz_host.html#order
источник
Слегка измененная версия вышеперечисленного, включая настраиваемую страницу, отображаемую тем, кому отказано в доступе:
... и таким образом те запросы, которые не поступают от 111.222.333.444, увидят конкретную_страницу.html
(публикация этого комментария выглядела ужасно, потому что новые строки терялись)
источник
test.html
и находится в той же папке, что и.htaccess
. Тем не менее, я не вижу журналы (не разрешено с сервера). У вас есть идея, почему у меня может быть такая проблема? Когда я получаю путь к файлу через FTP-клиент, он говорит мне,/test.html
что путь не должен быть проблемой, верно?Улучшая немного больше предыдущих ответов, страница обслуживания может быть показана вашим пользователям, пока вы вносите изменения на сайте:
Куда:
#.#.#.#
ваш IP: Что такое мой IP-адрес?maintenance.html
есть хороший пример здесь: Простота в обслуживании Pageисточник
В дополнение к ответу @David Brown, если вы хотите заблокировать IP, вы должны сначала разрешить всем, а затем блокировать IP как таковые:
Вы можете использовать любое из обозначений, упомянутых выше, в соответствии с вашими потребностями CIDR.
источник
Вы можете использовать следующее в htaccess, чтобы разрешить и запретить доступ к вашему сайту:
Сначала мы устанавливаем env-переменную allowip, если ip-адрес клиента соответствует шаблону, если шаблон соответствует, тогда переменной env allowip присваивается значение 1 .
На следующем шаге мы используем директивы Allow, deny, чтобы разрешить и запретить доступ к сайту.
Order deny,allow
представляет порядокdeny
иallow
.deny from all
эта строка говорит серверу запретить всем. последняя строкаallow from env=allowedip
позволяет получить доступ к одному IP-адресу, для которого мы устанавливаем переменную env.Замените
1\.2\.3\.4\.5
на ваш разрешенный IP-адрес.Ссылки:
https://httpd.apache.org/docs/2.4/mod/mod_setenvif.html
https://httpd.apache.org/docs/2.4/mod/mod_access_compat.html
источник
Я не смог использовать метод 403, поскольку хотел, чтобы страница обслуживания и изображения страниц находились в подпапке на моем сервере, поэтому использовал следующий подход для перенаправления на «страницу обслуживания» для всех, кроме одного IP *
Источник: создание страницы для скрытия вашего блога на WordPress.
источник
Вы можете иметь более одного IP-адреса или даже другой вид разрешения, например, имя пользователя, имя хоста, ... подробнее здесь https://www.askapache.com/htaccess/setenvif/
источник
Если вы хотите использовать mod_rewrite для контроля доступа, вы можете использовать такие условия, как пользовательский агент, http referrer, удаленный адрес и т. Д.
пример
Refrences:
источник
Добавьте следующую команду в файл .htaccess. И поместите этот файл в вашу папку htdocs.
источник
Мне кажется, это работает (с использованием IPv6, а не IPv4). Я не знаю, отличается ли это для некоторых веб-сайтов, но для моего это работает.
источник