8 date: "2016-06-26T10:40:45+00:00"
9 guid: http://juplo.de/?p=462
12 title: Configure pac4j for a Social-Login along with a Spring-Security based Form-Login
13 url: /configure-pac4j-for-a-social-login-along-with-a-spring-security-based-form-login/
16 ## The Problem – What will be explained
18 If you just want to enable your spring-based webapplication to let users log in with their social accounts, without changing anything else, [pac4j](http://www.pac4j.org/#1 "The authentication solution for java") should be your first choice.
19 But the [provided example](https://github.com/pac4j/spring-security-pac4j-demo "Clone the examples on GitHub") only shows, how to define all authentication mechanisms via pac4j.
20 If you already have set up your log-in via spring-security, you have to reconfigure it with the appropriate pac4j-mechanism.
21 That is a lot of unnecessary work, if you just want to supplement the already configured log in with the additionally possibility, to log in via a social provider.
23 In this short article, I will show you, how to set that up along with the normal [form-based login of Spring-Security](http://docs.spring.io/spring-security/site/docs/4.0.1.RELEASE/reference/htmlsingle/#ns-form-and-basic "Read, how to set up the form-based login of Spring-Security").
24 I will show this for a Login via Facabook along the Form-Login of Spring-Security.
25 The method should work as well for [other social logins, that are supported by spring-security-pac4j](https://github.com/pac4j/spring-security-pac4j#providers-supported "See a list of all login-mechanisms, supported by spring-security-pac4j"), along other login-mechanisms provided by spring-security out-of-the-box.
27 In this article I will not explain, how to store the user-profile-data, that was retrieved during the social login.
28 Also, if you need more social interaction, than just a login and access to the default data in the user-profile you probably need [spring-social](http://projects.spring.io/spring-social/ "Homepage of the spring-social project"). How to combine spring-social with spring-security for that purpose, is explained in this nice article about how to [add social sign in to a spring-mvc weba-pplication](http://www.petrikainulainen.net/programming/spring-framework/adding-social-sign-in-to-a-spring-mvc-web-application-configuration/ "Read this article about how to integrate spring-security with spring-social").
30 ## Adding the Required Maven-Artifacts
32 In order to use spring-security-pac4j to login to facebook, you need the following maven-artifacts:
36 <groupId>org.pac4j</groupId>
37 <artifactId>spring-security-pac4j</artifactId>
38 <version>1.2.5</version>
41 <groupId>org.pac4j</groupId>
42 <artifactId>pac4j-http</artifactId>
43 <version>1.7.1</version>
46 <groupId>org.pac4j</groupId>
47 <artifactId>pac4j-oauth</artifactId>
48 <version>1.7.1</version>
52 ## Configuration of Spring-Security (Without Social Login via pac4j)
54 This is a bare minimal configuration to get the form-login via Spring-Security working:
57 <?xml version="1.0" encoding="UTF-8"?>
59 xmlns="http://www.springframework.org/schema/beans"
60 xmlns:security="http://www.springframework.org/schema/security"
61 xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
63 http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-3.0.xsd
64 http://www.springframework.org/schema/security http://www.springframework.org/schema/security/spring-security-3.2.xsd
67 <security:http use-expressions="true">
68 <security:intercept-url pattern="/**" access="permitAll"/>
69 <security:intercept-url pattern="/home.html" access="isAuthenticated()"/>
70 <security:form-login login-page="/login.html" authentication-failure-url="/login.html?failure"/>
72 <security:remember-me/>
75 <security:authentication-manager>
76 <security:authentication-provider>
77 <security:user-service>
78 <security:user name="user" password="user" authorities="ROLE_USER" />
79 </security:user-service>
80 </security:authentication-provider>
81 </security:authentication-manager>
86 The `http` defines, that the access to the url `/home.html` is restriced and must be authenticated via a form-login on url `/login.html`.
87 The `authentication-manager` defines an in-memory authentication-provider for testing purposes with just one user (username: `user`, password: `user`).
88 For more details, see the [documentation of spring-security](http://docs.spring.io/spring-security/site/docs/4.0.1.RELEASE/reference/htmlsingle/#ns-form-and-basic "Read more about the available configuration-parameters in the spring-security documentation").
90 ## Enabling pac4j via spring-security-pac4j alongside
92 To enable pac4j alongside, you have to add/change the following:
95 <?xml version="1.0" encoding="UTF-8"?>
97 xmlns="http://www.springframework.org/schema/beans"
98 xmlns:security="http://www.springframework.org/schema/security"
99 xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
101 http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-3.0.xsd
102 http://www.springframework.org/schema/security http://www.springframework.org/schema/security/spring-security-3.2.xsd
105 <security:http use-expressions="true">
106 <security:custom-filter position="OPENID_FILTER" ref="clientFilter"/>
107 <security:intercept-url pattern="/**" access="permitAll()"/>
108 <security:intercept-url pattern="/home.html" access="isAuthenticated()"/>
109 <security:form-login login-page="/login.html" authentication-failure-url="/login.html?failure"/>
113 <security:authentication-manager alias="authenticationManager">
114 <security:authentication-provider>
115 <security:user-service>
116 <security:user name="user" password="user" authorities="ROLE_USER" />
117 </security:user-service>
118 </security:authentication-provider>
119 <security:authentication-provider ref="clientProvider"/>
120 </security:authentication-manager>
122 <!-- entry points -->
123 <bean id="facebookEntryPoint" class="org.pac4j.springframework.security.web.ClientAuthenticationEntryPoint">
124 <property name="client" ref="facebookClient"/>
127 <!-- client definitions -->
128 <bean id="facebookClient" class="org.pac4j.oauth.client.FacebookClient">
129 <property name="key" value="145278422258960"/>
130 <property name="secret" value="be21409ba8f39b5dae2a7de525484da8"/>
132 <bean id="clients" class="org.pac4j.core.client.Clients">
133 <property name="callbackUrl" value="http://localhost:8080/callback"/>
134 <property name="clients">
136 <ref bean="facebookClient"/>
141 <!-- common to all clients -->
142 <bean id="clientFilter" class="org.pac4j.springframework.security.web.ClientAuthenticationFilter">
143 <constructor-arg value="/callback"/>
144 <property name="clients" ref="clients"/>
145 <property name="sessionAuthenticationStrategy" ref="sas"/>
146 <property name="authenticationManager" ref="authenticationManager"/>
148 <bean id="clientProvider" class="org.pac4j.springframework.security.authentication.ClientAuthenticationProvider">
149 <property name="clients" ref="clients"/>
151 <bean id="httpSessionRequestCache" class="org.springframework.security.web.savedrequest.HttpSessionRequestCache"/>
152 <bean id="sas" class="org.springframework.security.web.authentication.session.SessionFixationProtectionStrategy"/>
159 1. You have to add an additional filter in `http`.
160 I added this filter on position `OPENID_FILTER`, because pac4j introduces a unified way to handle OpenID and OAuth and so on.
161 If you are using the OpenID-mechanism of spring-security, you have to use another position in the filter-chain (for example `CAS_FILTER`) or reconfigure OpenID to use the pac4j-mechanism, which should be fairly straight-forward.
164 The new Filter has the ID `clientFilter` and needs a reference to the `authenticationManager`.
165 Also, the callback-URL (here: `/callback`) must be mapped to your web-application!
167 1. You have to add an additional `authentication-provider` to the `authentication-manager`, that references your newly defined pac4j-ClientProvider ( `clientProvider`).
169 1. You have to configure your entry-points as pac4j-clients.
170 In the example above, only one pac4j-client, that authenticats the user via Facebook, is configured.
171 You easily can add more clients: just copy the definitions from the [spring-security-pac4j example](https://github.com/pac4j/spring-security-pac4j-demo "Browse the source of that example on GitHub").
173 That should be all, that is necessary, to enable a Facebook-Login in your Spring-Security web-application.
175 ## Do Not Forget To Use Your Own APP-ID!
177 The App-ID `145278422258960` and the accompanying secret `be21409ba8f39b5dae2a7de525484da8` were taken from the [spring-security-pac4j example](https://github.com/pac4j/spring-security-pac4j-demo "Browse the source of that example on GitHub") for simplicity.
178 That works for a first test-run on `localhost`.
179 _But you have to replace that with your own App-ID and -scecret, that you have to generate using [your App Dashboard on Facebook](https://developers.facebook.com/apps "You can generate your own apps on your App Dashboard")!_
183 This short article does not show, how to save the retrieved user-profiles in your user-database, if you need that.
184 I hope, I will write a follow-up on that soon.
186 pac4j creates a Spring-Security `UserDetails`-Instance for every user, that was authenticated against it.
187 You can use this, to access the data in the retrieved user-profile (for example to write out the name of the user in a greeting or contact him via e-mail).