Сервер localhost, чтобы получить доступ к страницам /admin/* и заблокировать все остальные
Требования:
- каждый в локальной сети может получить доступ ко всем страницам, кроме страниц /admin.
- только 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());
}