]> juplo.de Git - website/blob
c00ef9f330dcadeb844a348fda59d5c97fa63c6c
[website] /
1 ---
2 _edit_last: "2"
3 categories:
4   - facebook
5   - java
6   - oauth2
7   - spring
8 date: "2015-06-28"
9 lastmod: "2016-06-26T10:40:45+00:00"
10 guid: http://juplo.de/?p=462
11 parent_post_id: null
12 post_id: "462"
13 title: Configure pac4j for a Social-Login along with a Spring-Security based Form-Login
14 url: /configure-pac4j-for-a-social-login-along-with-a-spring-security-based-form-login/
15
16 ---
17 ## The Problem – What will be explained
18
19 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.
20 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.
21 If you already have set up your log-in via spring-security, you have to reconfigure it with the appropriate pac4j-mechanism.
22 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
24 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").
25 I will show this for a Login via Facabook along the Form-Login of Spring-Security.
26 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
28 In this article I will not explain, how to store the user-profile-data, that was retrieved during the social login.
29 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
31 ## Adding the Required Maven-Artifacts
32
33 In order to use spring-security-pac4j to login to facebook, you need the following maven-artifacts:
34
35 ```xml
36 <dependency>
37   <groupId>org.pac4j</groupId>
38   <artifactId>spring-security-pac4j</artifactId>
39   <version>1.2.5</version>
40 </dependency>
41 <dependency>
42   <groupId>org.pac4j</groupId>
43   <artifactId>pac4j-http</artifactId>
44   <version>1.7.1</version>
45 </dependency>
46 <dependency>
47   <groupId>org.pac4j</groupId>
48   <artifactId>pac4j-oauth</artifactId>
49   <version>1.7.1</version>
50 </dependency>
51 ```
52
53 ## Configuration of Spring-Security (Without Social Login via pac4j)
54
55 This is a bare minimal configuration to get the form-login via Spring-Security working:
56
57 ```xml
58 <?xml version="1.0" encoding="UTF-8"?>
59 <beans
60     xmlns="http://www.springframework.org/schema/beans"
61     xmlns:security="http://www.springframework.org/schema/security"
62     xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
63     xsi:schemaLocation="
64       http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-3.0.xsd
65       http://www.springframework.org/schema/security http://www.springframework.org/schema/security/spring-security-3.2.xsd
66     ">
67
68   <security:http use-expressions="true">
69     <security:intercept-url pattern="/**" access="permitAll"/>
70     <security:intercept-url pattern="/home.html" access="isAuthenticated()"/>
71     <security:form-login login-page="/login.html" authentication-failure-url="/login.html?failure"/>
72     <security:logout/>
73     <security:remember-me/>
74   </security:http>
75
76   <security:authentication-manager>
77     <security:authentication-provider>
78       <security:user-service>
79         <security:user name="user" password="user" authorities="ROLE_USER" />
80       </security:user-service>
81     </security:authentication-provider>
82   </security:authentication-manager>
83
84 </beans>
85 ```
86
87 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`.
88 The `authentication-manager` defines an in-memory authentication-provider for testing purposes with just one user (username: `user`, password: `user`).
89 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
91 ## Enabling pac4j via spring-security-pac4j alongside
92
93 To enable pac4j alongside, you have to add/change the following:
94
95 ```xml
96 <?xml version="1.0" encoding="UTF-8"?>
97 <beans
98     xmlns="http://www.springframework.org/schema/beans"
99     xmlns:security="http://www.springframework.org/schema/security"
100     xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
101     xsi:schemaLocation="
102       http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-3.0.xsd
103       http://www.springframework.org/schema/security http://www.springframework.org/schema/security/spring-security-3.2.xsd
104     ">
105
106   <security:http use-expressions="true">
107     <security:custom-filter position="OPENID_FILTER" ref="clientFilter"/>
108     <security:intercept-url pattern="/**" access="permitAll()"/>
109     <security:intercept-url pattern="/home.html" access="isAuthenticated()"/>
110     <security:form-login login-page="/login.html" authentication-failure-url="/login.html?failure"/>
111     <security:logout/>
112   </security:http>
113
114   <security:authentication-manager alias="authenticationManager">
115     <security:authentication-provider>
116       <security:user-service>
117         <security:user name="user" password="user" authorities="ROLE_USER" />
118       </security:user-service>
119     </security:authentication-provider>
120     <security:authentication-provider ref="clientProvider"/>
121   </security:authentication-manager>
122
123   <!-- entry points -->
124   <bean id="facebookEntryPoint" class="org.pac4j.springframework.security.web.ClientAuthenticationEntryPoint">
125     <property name="client" ref="facebookClient"/>
126   </bean>
127
128   <!-- client definitions -->
129   <bean id="facebookClient" class="org.pac4j.oauth.client.FacebookClient">
130     <property name="key" value="145278422258960"/>
131     <property name="secret" value="be21409ba8f39b5dae2a7de525484da8"/>
132   </bean>
133   <bean id="clients" class="org.pac4j.core.client.Clients">
134     <property name="callbackUrl" value="http://localhost:8080/callback"/>
135     <property name="clients">
136       <list>
137         <ref bean="facebookClient"/>
138       </list>
139     </property>
140   </bean>
141
142   <!-- common to all clients -->
143   <bean id="clientFilter" class="org.pac4j.springframework.security.web.ClientAuthenticationFilter">
144     <constructor-arg value="/callback"/>
145     <property name="clients" ref="clients"/>
146     <property name="sessionAuthenticationStrategy" ref="sas"/>
147     <property name="authenticationManager" ref="authenticationManager"/>
148   </bean>
149   <bean id="clientProvider" class="org.pac4j.springframework.security.authentication.ClientAuthenticationProvider">
150     <property name="clients" ref="clients"/>
151   </bean>
152   <bean id="httpSessionRequestCache" class="org.springframework.security.web.savedrequest.HttpSessionRequestCache"/>
153   <bean id="sas" class="org.springframework.security.web.authentication.session.SessionFixationProtectionStrategy"/>
154
155 </beans>
156 ```
157
158 In short:
159
160 1. You have to add an additional filter in `http`.
161    I added this filter on position `OPENID_FILTER`, because pac4j introduces a unified way to handle OpenID and OAuth and so on.
162    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.
163
164
165    The new Filter has the ID `clientFilter` and needs a reference to the `authenticationManager`.
166    Also, the callback-URL (here: `/callback`) must be mapped to your web-application!
167
168 1. You have to add an additional `authentication-provider` to the `authentication-manager`, that references your newly defined pac4j-ClientProvider ( `clientProvider`).
169
170 1. You have to configure your entry-points as pac4j-clients.
171    In the example above, only one pac4j-client, that authenticats the user via Facebook, is configured.
172    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
174 That should be all, that is necessary, to enable a Facebook-Login in your Spring-Security web-application.
175
176 ## Do Not Forget To Use Your Own APP-ID!
177
178 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.
179 That works for a first test-run on `localhost`.
180 _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")!_
181
182 ## More to come...
183
184 This short article does not show, how to save the retrieved user-profiles in your user-database, if you need that.
185 I hope, I will write a follow-up on that soon.
186 In short:
187 pac4j creates a Spring-Security `UserDetails`-Instance for every user, that was authenticated against it.
188 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).