Сервер localhost, чтобы получить доступ к страницам /admin/* и заблокировать все остальные

Требования:

  1. каждый в локальной сети может получить доступ ко всем страницам, кроме страниц /admin.
  2. только localhost должен иметь доступ к страницам /admin.

Как написать веб-фильтр для Tomcat 6 или другие альтернативы?

1 ответ

Пожалуйста, используйте следующий код в фильтре, чтобы проверить, является ли запрос "admin":

public static boolean isRequestTo(HttpServletRequest request, String urlPart) {
    return request.getRequestURI().startsWith(urlPart);
}

Пожалуйста, используйте следующий код в фильтре, чтобы проверить, был ли запрос от localhost:

private static final String LOCAL_IP = "127.0.0.1";
private static final String LOCAL_IPV6 = "0:0:0:0:0:0:0:1";

private static Set<String> localAddresses = new HashSet<String>();

static {
    try {
        localAddresses.add(InetAddress.getLocalHost().getHostAddress());
        for (InetAddress inetAddress : InetAddress.getAllByName("localhost")) {
            localAddresses.add(inetAddress.getHostAddress());
        }
    } catch (Exception e) {
        if (!localAddresses.contains(LOCAL_IP)) {
            localAddresses.add(LOCAL_IP);
        }

        if (!localAddresses.contains(LOCAL_IPV6)) {
            localAddresses.add(LOCAL_IPV6);
        }
    }
}

public static boolean isLocalRequest(HttpServletRequest request) {
    return localAddresses.contains(request.getRemoteAddr());
}
Другие вопросы по тегам