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