Я написал логин для своего проекта JSF и определил небольшой частный раздел для его проверки.JSF Перенаправление на запрашиваемую страницу после входа в систему
Это мой LoginFilter:
@WebFilter("/private/*")
public class LoginFilter implements Filter {
@Inject
private NavigationService navigationService = null;
@Override
public void init(FilterConfig config) throws ServletException {}
@Override
public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException {
HttpServletRequest req = (HttpServletRequest)request;
HttpServletResponse res = (HttpServletResponse)response;
String originalURL = req.getRequestURL().toString();
if(req.getQueryString() != null) {
originalURL += "?" + req.getQueryString();
}
User user = (User) req.getSession().getAttribute("user");
if(user != null) {
chain.doFilter(request, response);
} else {
req.getSession().setAttribute("originalURL", originalURL);
res.sendRedirect(req.getContextPath() + navigationService.toLogin());
}
}
@Override
public void destroy() {}
}
Это мой LoginService:
@Named
@SessionScoped
public class LoginService implements Serializable {
private String username = "";
private String password = "";
@Inject
private NavigationService navigationService = null;
@Inject
private DAO dao = null;
private String originalURL = "";
@PostConstruct
public void init() {
ExternalContext externalContext = FacesContext.getCurrentInstance().getExternalContext();
if(externalContext.getRequestMap().containsKey("originalURL")) {
this.originalURL = (String)externalContext.getRequestMap().get("originalURL");
} else {
this.originalURL = navigationService.externalContextRedirectToIndex();
}
}
public void doLogin() throws IOException, NoSuchAlgorithmException, InvalidKeySpecException {
FacesContext context = FacesContext.getCurrentInstance();
ExternalContext externalContext = context.getExternalContext();
User user = dao.findUserByUsername(this.username);
boolean validated = PasswordHasher.validatePassword(this.password, user.getPassword());
if(user != null && validated) {
externalContext.getSessionMap().put("user", user);
vexternalContext.redirect(this.originalURL);
} else {
context.addMessage(null, new FacesMessage("False username or password!"));
}
}
public void doLogout() throws IOException {
ExternalContext externalContext = FacesContext.getCurrentInstance().getExternalContext();
externalContext.invalidateSession();
externalContext.redirect(externalContext.getRequestContextPath() + navigationService.toLogin());
}
// Getter and Setter
}
если сейчас кто-то просит, например, "/private/test.html" моя страница Войти появляется и пользователь должен войти в систему. После этого, если пользователь успешно зарегистрирован , я хочу перенаправить на первоначально запрошенный файл test.html.
Теперь у sessionMap никогда нет ключа с именем «originalURL», и я всегда получаю , перенаправленный на мой index.html.
Btw мой NavigationService включает два метода:
public String redirectToIndex() {
return "/index.html?faces-redirect=true";
}
public String externalContextRedirectToIndex() {
return "/Web-Tschuwwa/index.html?faces-redirect=true";
}
Второй метод я должен был добавить специально для перенаправления после входа , потому что, когда я использовал первый метод я был перенаправлен на index.html из моя папка docsroot из морской рыбы. Это другое дело, я не знаю, почему. Web-Tschuwwa - это название моего проекта.
Как я могу перенаправить на запрашиваемую страницу после входа?