У меня есть фильтр, используемый для входа. Он выполняет текстовую проверку в полях "Имя пользователя" и "Пароль". Если и только если текстовая проверка выполнена правильно, запрос отправляется на Servlet. Этот последний выполняет элемент управления, который должен взаимодействовать с базой данных. Правильно ли эта цепочка?
Фильтр аутентификации и сервлет для входа в систему
Ответ 1
Предисловие. Похоже, вы используете вход для входа в систему вместо входа в управляемый контейнером. Для всех путей см. Как обрабатывать аутентификацию/авторизацию с пользователями в базе данных?
Фильтр (перехватчик) не должен проверять правильность комбинации имени пользователя и пароля. Это ответственность сервлета (контроллера).
Фильтр должен просто проверять, вошел ли пользователь в систему (обычно, просто проверяя наличие атрибута сеанса), а затем продолжить запрос или заблокировать его, перенаправив его обратно на страницу входа.
@WebFilter("/*")
public class LoginFilter implements Filter {
@Override
public void doFilter(ServletRequest req, ServletResponse res, FilterChain chain) throws ServletException, IOException {
HttpServletRequest request = (HttpServletRequest) req;
HttpServletResponse response = (HttpServletResponse) res;
HttpSession session = request.getSession(false);
String loginURI = request.getContextPath() + "/login";
boolean loggedIn = session != null && session.getAttribute("user") != null;
boolean loginRequest = request.getRequestURI().equals(loginURI);
if (loggedIn || loginRequest) {
chain.doFilter(request, response);
} else {
response.sendRedirect(loginURI);
}
}
// ...
}
Сервлет должен собрать предоставленные данные, найти связанную User
в базе данных и, если он будет найден, сохранить его как атрибут сеанса, а затем перенаправить на домашнюю страницу, иначе повторно отобразить форму с ошибками проверки.
@WebServlet("/login")
public class LoginServlet extends HttpServlet {
@EJB
private UserService userService;
@Override
protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
request.getRequestDispatcher("/WEB-INF/login.jsp").forward(request, response);
}
@Override
protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
String username = request.getParameter("username");
String password = request.getParameter("password");
Map<String, String> messages = new HashMap<String, String>();
if (username == null || username.isEmpty()) {
messages.put("username", "Please enter username");
}
if (password == null || password.isEmpty()) {
messages.put("password", "Please enter password");
}
if (messages.isEmpty()) {
User user = userService.find(username, password);
if (user != null) {
request.getSession().setAttribute("user", user);
response.sendRedirect(request.getContextPath() + "/home");
return;
} else {
messages.put("login", "Unknown login, please try again");
}
}
request.setAttribute("messages", messages);
request.getRequestDispatcher("/WEB-INF/login.jsp").forward(request, response);
}
}