Java Doc for AuthenticationFilter.java in  » Database-ORM » Velosurf » velosurf » web » auth » Java Source Code / Java DocumentationJava Source Code and Java Documentation

Java Source Code / Java Documentation
1. 6.0 JDK Core
2. 6.0 JDK Modules
3. 6.0 JDK Modules com.sun
4. 6.0 JDK Modules com.sun.java
5. 6.0 JDK Modules sun
6. 6.0 JDK Platform
7. Ajax
8. Apache Harmony Java SE
9. Aspect oriented
10. Authentication Authorization
11. Blogger System
12. Build
13. Byte Code
14. Cache
15. Chart
16. Chat
17. Code Analyzer
18. Collaboration
19. Content Management System
20. Database Client
21. Database DBMS
22. Database JDBC Connection Pool
23. Database ORM
24. Development
25. EJB Server geronimo
26. EJB Server GlassFish
27. EJB Server JBoss 4.2.1
28. EJB Server resin 3.1.5
29. ERP CRM Financial
30. ESB
31. Forum
32. GIS
33. Graphic Library
34. Groupware
35. HTML Parser
36. IDE
37. IDE Eclipse
38. IDE Netbeans
39. Installer
40. Internationalization Localization
41. Inversion of Control
42. Issue Tracking
43. J2EE
44. JBoss
45. JMS
46. JMX
47. Library
48. Mail Clients
49. Net
50. Parser
51. PDF
52. Portal
53. Profiler
54. Project Management
55. Report
56. RSS RDF
57. Rule Engine
58. Science
59. Scripting
60. Search Engine
61. Security
62. Sevlet Container
63. Source Control
64. Swing Library
65. Template Engine
66. Test Coverage
67. Testing
68. UML
69. Web Crawler
70. Web Framework
71. Web Mail
72. Web Server
73. Web Services
74. Web Services apache cxf 2.0.1
75. Web Services AXIS2
76. Wiki Engine
77. Workflow Engines
78. XML
79. XML UI
Java
Java Tutorial
Java Open Source
Jar File Download
Java Articles
Java Products
Java by API
Photoshop Tutorials
Maya Tutorials
Flash Tutorials
3ds-Max Tutorials
Illustrator Tutorials
GIMP Tutorials
C# / C Sharp
C# / CSharp Tutorial
C# / CSharp Open Source
ASP.Net
ASP.NET Tutorial
JavaScript DHTML
JavaScript Tutorial
JavaScript Reference
HTML / CSS
HTML CSS Reference
C / ANSI-C
C Tutorial
C++
C++ Tutorial
Ruby
PHP
Python
Python Tutorial
Python Open Source
SQL Server / T-SQL
SQL Server / T-SQL Tutorial
Oracle PL / SQL
Oracle PL/SQL Tutorial
PostgreSQL
SQL / MySQL
MySQL Tutorial
VB.Net
VB.Net Tutorial
Flash / Flex / ActionScript
VBA / Excel / Access / Word
XML
XML Tutorial
Microsoft Office PowerPoint 2007 Tutorial
Microsoft Office Excel 2007 Tutorial
Microsoft Office Word 2007 Tutorial
Java Source Code / Java Documentation » Database ORM » Velosurf » velosurf.web.auth 
Source Cross Reference  Class Diagram Java Document (Java Doc) 


java.lang.Object
   velosurf.web.auth.AuthenticationFilter

AuthenticationFilter
public class AuthenticationFilter implements Filter(Code)

This class is a servlet filter used to protect web pages behind an authentication mechanism. When a non-authenticated user requests a private page, (s)he is redirected towards the login page and thereafter, if (s)he loggued in successfully, towards his(her) initially requested page.

Authentication is performed via a CRAM (challenge-response authentication mechanism). Passwords are encrypted using the method given as parameter to the Authenticator tool in toolbox.xml. The provided Javascript file /src/javascript/md5.js implements the HmacMD5 method on the client side.

This filter works in conjunction with an Authenticator object that must be present in the session scope of the toolbox and with a javascript password encryption function.

To use it, you just have to map private urls (and especially, the target of the login form, this is very important for the authentication to work properly!) to go through this filter, as in :

<filter> <filter-name>authentication</filter-name> <filter-class>auth.AuthenticationFilter</filter-class> </filter> <filter-mapping> <filter-name>authentication</filter-name> <url-pattern>/auth/*</url-pattern> </filter-mapping>

The password is encrypted in an irreversible manner into an answer, and to check the login, the answer that the client sends back to the server is compared to the correct awaited answer.

The javascript file login.js.vtl contains the necessary encryption functions. It uses the bignum.js library file. You will find those files in /src/resources/auth or in the auth-l10n sample webapp.

The filter expect the login to be present in the HTTP 'login' form field, and the answer in the 'answer' form field (which should be all right if you use the login.js.vtl as is). The action of the form is never used (since the filter will redirect the user towards the page asked before the login), but it must be catched by an url-pattern of this filter. You can for instance define a mapping towards "/process_login".

The loggued state is materialized by the presence of a user Object in the session under the user key. This user object in the one returned by the abstract method Authenticator.getUser(login).

This filter will search for an occurrence of a localizer tool in the session toolbox to resolve some values. The presence of this localizer is optional.

Optional configuration parameters:

  • login-field: name of the login form field.
  • password-field: name of the password field.
  • max-inactive: delay upon which an inactive user is disconnected in seconds. The default value is one hour.
  • login-page: the login page URI. The "@" pattern applies as well. Default is '/login.html'.
  • authenticated-index-page: the default page once authenticated. The "@" pattern applies as well. Default is '/loggued.html'.
  • bad-login-message: the message to be displayed in case of bad login. If this parameter is not specified, the filter will try to get a reference from the localizer tool and ask it for a "badLogin" message, and if this fails, it will simply use "Bad login or password.".
  • disconnected-message: the message to be displayed when the user is disconnected after a period of inactivity on the site. Same remark if this parameter is not supplied: the filter will search for a "disconnected" message in the localizer tool if present, and otherwise display "You have been disconnected."


author:
   Claude Brisson




Method Summary
protected  voidbadLogin(HttpServletRequest request, HttpServletResponse response, FilterChain chain)
    
public  voiddestroy()
     Destroy the filter.
public  voiddoFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain chain)
     Filtering.
protected  voiddoLogin(HttpServletRequest request, HttpServletResponse response, FilterChain chain)
    
protected  voiddoLogout(HttpServletRequest request, HttpServletResponse response, FilterChain chain)
    
protected  voiddoProcessAuthentified(HttpServletRequest request, HttpServletResponse response, FilterChain chain)
    
protected  voiddoRedirect(HttpServletRequest request, HttpServletResponse response, FilterChain chain)
    
protected  StringgetAuthenticatedIndexPage()
    
protected  StringgetMessage(Localizer localizer, String key, String defaultMessage)
     Message getter.
protected  voidgoodLogin(HttpServletRequest request, HttpServletResponse response, FilterChain chain)
    
public  voidinit(FilterConfig config)
     Initialization.
protected  StringresolveLocalizedUri(HttpServletRequest request, String uri)
    



Method Detail
badLogin
protected void badLogin(HttpServletRequest request, HttpServletResponse response, FilterChain chain) throws IOException, ServletException(Code)



destroy
public void destroy()(Code)
Destroy the filter.



doFilter
public void doFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain chain) throws IOException, ServletException(Code)
Filtering.
Parameters:
  servletRequest - request
Parameters:
  servletResponse - response
Parameters:
  chain - filter chain
throws:
  IOException -
throws:
  ServletException -



doLogin
protected void doLogin(HttpServletRequest request, HttpServletResponse response, FilterChain chain) throws IOException, ServletException(Code)



doLogout
protected void doLogout(HttpServletRequest request, HttpServletResponse response, FilterChain chain) throws IOException, ServletException(Code)



doProcessAuthentified
protected void doProcessAuthentified(HttpServletRequest request, HttpServletResponse response, FilterChain chain) throws IOException, ServletException(Code)



doRedirect
protected void doRedirect(HttpServletRequest request, HttpServletResponse response, FilterChain chain) throws IOException, ServletException(Code)



getAuthenticatedIndexPage
protected String getAuthenticatedIndexPage()(Code)



getMessage
protected String getMessage(Localizer localizer, String key, String defaultMessage)(Code)
Message getter.
Parameters:
  localizer - localizer
Parameters:
  key - key
Parameters:
  defaultMessage - default message localized message or default message



goodLogin
protected void goodLogin(HttpServletRequest request, HttpServletResponse response, FilterChain chain) throws IOException, ServletException(Code)



init
public void init(FilterConfig config) throws ServletException(Code)
Initialization.
Parameters:
  config - filter config
throws:
  ServletException -



resolveLocalizedUri
protected String resolveLocalizedUri(HttpServletRequest request, String uri)(Code)



Methods inherited from java.lang.Object
native protected Object clone() throws CloneNotSupportedException(Code)(Java Doc)
public boolean equals(Object obj)(Code)(Java Doc)
protected void finalize() throws Throwable(Code)(Java Doc)
final native public Class getClass()(Code)(Java Doc)
native public int hashCode()(Code)(Java Doc)
final native public void notify()(Code)(Java Doc)
final native public void notifyAll()(Code)(Java Doc)
public String toString()(Code)(Java Doc)
final native public void wait(long timeout) throws InterruptedException(Code)(Java Doc)
final public void wait(long timeout, int nanos) throws InterruptedException(Code)(Java Doc)
final public void wait() throws InterruptedException(Code)(Java Doc)

www.java2java.com | Contact Us
Copyright 2009 - 12 Demo Source and Support. All rights reserved.
All other trademarks are property of their respective owners.