- 
        1. Re: cannot get original request URI on JSF2 based form login pagesfcoy Jul 21, 2012 7:53 AM (in response to j_ri)Form based login has always been a bit pathologically private in that users are not intended to link directly to the login form. The idea is that when a user attempts to access a protected resource, the container automatically invokes the login form, and then redirects to the original URL following successful authorisation. You would not normally perform this redirection yourself. 
- 
        2. Re: cannot get original request URI on JSF2 based form login pagej_ri Jul 22, 2012 4:34 AM (in response to sfcoy)But why was HttpServletRequest.login(username, password) introduced with servlet-specification 3.0, if you shouldn't use it? Actually the "/j_security_check" method is sufficient. But if you use a custom page, you can have better info/error messages..... 
- 
        3. Re: cannot get original request URI on JSF2 based form login pagesfcoy Jul 22, 2012 6:50 AM (in response to j_ri)That's different. Either you manage the login process, or let the container do it (via /j_security_check, etc). I suspect that mixing the two may lead to confusion. 
- 
        4. Re: cannot get original request URI on JSF2 based form login pagej_ri Jul 22, 2012 7:29 AM (in response to sfcoy)Sorry, I don't agree, since the new Servlet 3.0 method HttpServletRequest.login(username, password) does exactly the same as "/j_security_check". It delegates the login process to the container. I think it was introduced to be able to make a "clean" JSF2 login page. With "/j_security_check" you have to implement a mix between JSF/Facelet tags and plain HTML for the form..... 
- 
        5. Re: cannot get original request URI on JSF2 based form login pagesfcoy Jul 22, 2012 10:38 AM (in response to j_ri)My reading of the spec differentiates "Declarative Security" and "Programmatic Security". It says this about programmatic security: The login method allows an application to perform username and password collection (as an alternative to Form-Based Login). The authenticate methods allow an application to instigate authentication of the request caller by the container from within an unconstrained request context. Declarative security consists of (amongst other things) Form-Based Login which uses the "/j_security_check" mechanism. But all of that is incidental really. JSF2/Facelets form based authentication (aka Declarative Security) works just fine for me. I've not needed to use Programmatic Security for this purpose. 
- 
        6. Re: cannot get original request URI on JSF2 based form login pagej_ri Jul 23, 2012 3:13 AM (in response to sfcoy)Which version of the spec did you cite? I just downloaded the 3.0 final spec and cite it like that: The authenticate method allows an application to perform username and password collection (as an alternative to Form-Based Login). The login methods allow an application to instigate authentication of the request caller by the container from within an unconstrained request context. I interpret this, as I already explained. "HttpServlerRequest.login(user, pwd)" delegated to the container. The actual question is: Is the container, based on the {code:xml} <form-login-config> <form-login-page>/login.jsf</form-login-page> <form-error-page>/login.jsf</form-error-page> </form-login-config> {code} configuration, doing a forward according to chapter 9.4.2 of the specs? If yes the "javax.servlet.forward.*" request attributes must be set. 
- 
        7. Re: cannot get original request URI on JSF2 based form login pagesfcoy Jul 23, 2012 3:37 AM (in response to j_ri)FWIW, I have: Version 3.0 Rev a Rajiv Mordani December 2010 The section I quoted has a change bar next to it . The behaviour of form based login is described in §13.6.3. There is nothing there that suggests that it will perform a servlet level "forward". It just renders the login form and returns it to the client instead of the requested resource. 
- 
        8. Re: cannot get original request URI on JSF2 based form login pagej_ri Jul 23, 2012 6:18 AM (in response to sfcoy)But all of that is incidental really. JSF2/Facelets form based authentication (aka Declarative Security) works just fine for me. I've not needed to use Programmatic Security for this purpose. IF the user entered the correct password and everything works fine the declarative security works for me, too. What I'm missing is the possibility to show messages. E.g. "Incorrect Password", "Account deactivated due to 5 tries", "LDAP not available", etc. How do you show these messages on the login page? 
- 
        9. Re: cannot get original request URI on JSF2 based form login pagesfcoy Jul 23, 2012 6:26 AM (in response to j_ri){code:xml}<form-error-page>/login.jsf?loginFailed=true</form-error-page>{code} {code:xml}<h:panelGroup layout="block" id="login-error" rendered="#{param['loginFailed']}">#{loginPage['message.authenticationFailed']}</h:panelGroup>{code} Never ever display any more information than "login failed", otherwise you give potential attackers clues as to how they may better proceed. 
- 
        10. Re: cannot get original request URI on JSF2 based form login pagej_ri Jul 23, 2012 9:29 AM (in response to sfcoy)we only use it for our inhouse applications, so the problem with potential attackers ist not that important. since we actually use SPNEGO based single-sign-on the form is only shown for developers..and if there is something wrong with the sso mechanism. and for the latter case I want to show the message who should be contacted. anyway, thanks you for hint with " <form-error-page>/login.jsf?loginFailed=true</form-error-page>". this should be sufficient for now.
 
    