Назад | Перейти на главную страницу

Ограничить доступ к index.php - Apache

поэтому я хочу ограничить доступ к моему index.php файл, когда запрос приходит с параметрами. Например:

Есть ли способ сделать это с помощью .htaccess файл?

Любая помощь приветствуется.

Вы можете сделать что-то вроде следующего, используя mod_rewrite, в верхней части вашего корня .htaccess файл:

RewriteEngine On
RewriteCond %{QUERY_STRING} ^param1=value1$
RewriteRule ^(index\.php)?$ - [F]

Это вернет 403 Forbidden, если будет запрошен любой из следующих URL:

  • /?param1=value1
  • /index.php?param1=value1

Обратите внимание, что это соответствует строке запроса (параметры URL) именно как указано в вашем примере. Все остальное будет разрешено.

ОБНОВИТЬ

как мне запретить доступ, если существуют какие-либо параметры?

В этом случае вы можете изменить состояние просто соответствовать что-нибудь. То есть что-то, но нет ничего. Например:

RewriteCond %{QUERY_STRING} .

Точка (.) соответствует любому символу.

Попробуй это:

RewriteEngine On
RewriteCond %{REQUEST_URI} =^param1=.+$ 
RewriteRule ^ /errors/no.access.html