Spring Security 3.1.2 with ICEFaces 3.1

Table of Contents

Spring Security 3.1.2 and ICEfaces 3.1 Tutorial

  Name Size Creator (Last Modifier) Creation Date Last Mod Date Comment  
ZIP Archive springsecurity-3.1.2-ICEFaces-3.1.zip 645 kB Greg Dick Sep 07, 2012 Sep 07, 2012 Spring security 3.1.2 ICEFaces 3.1 example app

About Spring Security

Spring Security 3 provides an API for configuring authentication and authorization. Authentication is possible against any number of repositories and databases. Authorization is applied at either the web resource level using Servlet Filters and/or at the business/service method level using aspects and annotations.

About This Tutorial

The purpose of this tutorial is to demonstrate how application developers can use both Spring Security 3.1.2 and ICEfaces 3.1 in the same application. Both technologies leverage the Servlet API so it is essential one understands how the various parts of the web.xml file are organized to accommodate both frameworks. Its also important to be mindful that Spring Security is highly configurable. The example below shows only one extension (Session Management). There are several others filters and configuration options your requirements may warrant. Note that the official Spring-Webflow release has not been updated to fix a problem with overloading methods in the FacesContext that throw UnsupportedOperationExceptions, so the maven Pom included in the tutorial refers to a temporary build location for Spring-Webflow.

Tutorial Use Case

The simple business case for this tutorial is a "product documentation" web application. Some of the documentation is publicly available and some of it requires authorization. To satisfy this requirement all content requiring authorization is accessible behind the spring intercept pattern "/secure/*"

Technologies/Libraries Used

This tutorial uses Spring Security 3.1.2, Spring Framework 3.0.6, JSF 2.1.6 and ICEfaces 3.1. The project has been modified to use Maven as the build environment.

Porting from Spring Security 3.0.6 and ICEFaces 3.0.1

In changing from the previous tutorial, users will note the following changes:

1) The security-config.xml file will need to name a new up-to-date Spring Security schema as in the following example:

Schema changes
<beans:beans xmlns="http://www.springframework.org/schema/security"
  xmlns:beans="http://www.springframework.org/schema/beans"
  xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
  xsi:schemaLocation="http://www.springframework.org/schema/beans
           http://www.springframework.org/schema/beans/spring-beans-3.0.xsd
           http://www.springframework.org/schema/security
           http://www.springframework.org/schema/security/spring-security-3.1.xsd">
    ...
</beans:beans>

2) The SessionManagementFilter no longer supports an invalidSessionURL property. Instead, if so desired, there is a new SessionManagement element within the <http> element.

Session Management
  <http>
    ...
    <session-management invalid-session-url="/invalidSession.htm" />
    </http>

With those changes in place, the tutorial operates as it did before.


Configuration Areas:

  1. Configure Your Web.xml For Spring Security
  2. Configure Your applicationContext.xml For Spring Security
  3. Configure Your Web.xml For JSF
  4. Advanced: Configure Your Spring Security redirectStrategy

Part 1: Configure Web.xml For Spring Security

The web.xml below contains additional parameters showing where the spring configuration is located, the Spring Security filter chain, the context loader listener, and the SessionEventPublisher. These should be added to any existing ICEfaces web.xml configuration parameters show below in step 3.

web.xml
<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns="http://java.sun.com/xml/ns/javaee"
         xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://java.sun.com/xml/ns/javaee
		  http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd"
         version="2.5">
    <context-param>
        <param-name>contextConfigLocation</param-name>
        <param-value>
            /WEB-INF/applicationContext.xml
            /WEB-INF/applicationContext-security.xml
        </param-value>
    </context-param>
   <filter>
        <filter-name>springSecurityFilterChain</filter-name>
        <filter-class>org.springframework.web.filter.DelegatingFilterProxy</filter-class>
    </filter>

    <filter-mapping>
        <filter-name>springSecurityFilterChain</filter-name>
        <url-pattern>/*</url-pattern>
    </filter-mapping>

    <listener>
        <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
    </listener>
    <listener>
        <listener-class>org.springframework.security.web.session.HttpSessionEventPublisher</listener-class>
    </listener> </web-app>

Part 2: Configure Your security-config.xml For Spring Security

In this step we configure Spring Security in the file security-config.xml.

security-config.xml
<?xml version="1.0" encoding="UTF-8"?>

<beans:beans xmlns="http://www.springframework.org/schema/security"
             xmlns:beans="http://www.springframework.org/schema/beans"
             xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
             xsi:schemaLocation="http://www.springframework.org/schema/beans
           http://www.springframework.org/schema/beans/spring-beans-3.0.xsd
           http://www.springframework.org/schema/security
           http://www.springframework.org/schema/security/spring-security-3.1.xsd">

    <!-- Configure Spring Security -->
    <http auto-config="false"
          use-expressions="true"
          access-denied-page="/spring/login">

        <form-login login-page="/spring/login"
                    login-processing-url="/spring/loginProcess"
                    default-target-url="/spring/main" always-use-default-target="true"
                    authentication-failure-url="/spring/login?login_error=1" />

        <!-- When using custom filters, please make sure the positions do not conflict with default filters.
            Alternatively you can disable the default filters by removing the corresponding child elements from
            http and avoiding the use of http auto-config='true'. -->

        <custom-filter ref="exceptionTranslationFilter" before="FILTER_SECURITY_INTERCEPTOR" />

        <!--<session-management invalid-session-url="/spring/sessionExpired.jsf"/>-->

        <logout logout-url="/spring/logout" logout-success-url="/spring/logoutSuccess"/>
        <intercept-url pattern="/secure" method="POST" access="hasRole('ROLE_SUPERVISOR')"/>
    </http>

    <!--
		Define local authentication provider, a real app would use an external provider (JDBC, LDAP, CAS, etc)

		usernames/passwords are:
			keith/melbourne
			erwin/leuven
			jeremy/atlanta
			scott/rochester
	-->
    <authentication-manager>
        <authentication-provider>
            <password-encoder hash="md5"/>
            <user-service>
                <user name="keith" password="417c7382b16c395bc25b5da1398cf076"
                      authorities="ROLE_USER, ROLE_SUPERVISOR"/>
                <user name="erwin" password="12430911a8af075c6f41c6976af22b09"
                      authorities="ROLE_USER, ROLE_SUPERVISOR"/>
                <user name="jeremy" password="57c6cbff0d421449be820763f03139eb" authorities="ROLE_USER"/>
                <user name="scott" password="942f2339bf50796de535a384f0d1af3e" authorities="ROLE_USER"/>
            </user-service>
        </authentication-provider>
    </authentication-manager>


    <beans:bean id="sessionManagementFilter"
            class="org.springframework.security.web.session.SessionManagementFilter">
        <beans:constructor-arg name="securityContextRepository" ref="httpSessionSecurityContextRepository" />
    </beans:bean>


    <!-- http://static.springsource.org/spring-security/site/docs/3.1.x/reference/core-web-filters.html -->
    <beans:bean id="exceptionTranslationFilter" class="org.springframework.security.web.access.ExceptionTranslationFilter">
      <beans:property name="accessDeniedHandler" ref="jsfAccessDeniedHandler"/>
      <beans:property name="authenticationEntryPoint" ref="authenticationEntryPoint"/>
    </beans:bean>

    <beans:bean id="jsfAccessDeniedHandler" class="com.icesoft.spring.security.JsfAccessDeniedHandler">
        <beans:property name="loginPath" value="/spring/login" />
        <beans:property name="contextRelative" value="true" />
    </beans:bean>

    <beans:bean  id="authenticationEntryPoint" class="com.icesoft.spring.security.JsfLoginUrlAuthenticationEntryPoint">
        <beans:property name="loginFormUrl" value="/spring/login"/>
        <beans:property name="redirectStrategy" ref="jsfRedirectStrategy" />
    </beans:bean >


    <beans:bean id="jsfRedirectStrategy" class="com.icesoft.spring.security.JsfRedirectStrategy"/>
    <beans:bean id="httpSessionSecurityContextRepository" class="org.springframework.security.web.context.HttpSessionSecurityContextRepository"/>

</beans:beans>

Part 3: Configure Web.xml For JSF

In this step we extend the web.xml to support JSF like we would any other ICEfaces application.

web.xml
...
    <servlet>
        <servlet-name>Faces Servlet</servlet-name>
        <servlet-class>javax.faces.webapp.FacesServlet</servlet-class>
        <load-on-startup>1</load-on-startup>
    </servlet>

    <servlet>
        <servlet-name>Resource Servlet</servlet-name>
        <servlet-class>com.icesoft.faces.webapp.CompatResourceServlet</servlet-class>
        <load-on-startup>1</load-on-startup>
    </servlet>

    <servlet-mapping>
        <servlet-name>Faces Servlet</servlet-name>
        <url-pattern>*.faces</url-pattern>
    </servlet-mapping>

    <servlet-mapping>
        <servlet-name>Faces Servlet</servlet-name>
        <url-pattern>/icefaces/*</url-pattern>
    </servlet-mapping>

    <servlet-mapping>
        <servlet-name>Resource Servlet</servlet-name>
        <url-pattern>/xmlhttp/*</url-pattern>
    </servlet-mapping>
...

Resources

For more information on Spring Security, please check out the content below:

Enter labels to add to this page:
Please wait 
Looking for a label? Just start typing.

© Copyright 2018 ICEsoft Technologies Canada Corp.