Весна Социальная и Угловая
Я ищу несколько примеров или статей, в которых объясняется, как интегрировать Spring social в мою архитектуру микро-сервисов, в частности, в мой сервер авторизации. Может ли sommeone объяснить, как я могу добавить Spring Social (Facebook и Google) в поток?
Как я упоминал ранее, я использую angular в качестве внешнего приложения, сейчас я обрабатываю поток паролей, пользователь вводит свое имя пользователя и пароль и получает токен JWT, этот токен используется при каждом вызове сервера ресурсов. Это моя конфигурация безопасности и конфигурации авторизации:
@EnableAuthorizationServer
@Configuration
public class ServersConfig extends AuthorizationServerConfigurerAdapter {
@Value("${security.oauth2.client-id}")
private String clientId;
@Value("${security.oauth2.signing-key}")
private String signingKey;
@Value("${security.oauth2.grant-type.password}")
private String grantTypePassword;
@Value("${security.oauth2.grant-type.authorization-code}")
private String grantTypeAuthorizationCode;
@Value("${security.oauth2.grant-type.refresh-token}")
private String grantTypeRefreshToken;
@Value("${security.oauth2.scope.web}")
private String scopeWeb;
@Value("${security.oauth2.scope.mobile}")
private String scopeMobile;
@Value("${security.oauth2.resources-ids.buy-sell}")
private String resourcesIdBuySell;
@Value("${security.oauth2.resources-ids.gateway}")
private String resourcesIdGateway;
@Value("${security.oauth2.resources-ids.upload}")
private String resourcesIdUpload;
@Value("${security.oauth2.access-token-validity-seconds}")
private String accessTokenValiditySeconds;
@Autowired
@Qualifier("authenticationManagerBean")
private AuthenticationManager authenticationManager;
@Bean
public JwtAccessTokenConverter accessTokenConverter() {
JwtAccessTokenConverter converter = new JwtAccessTokenConverter();
converter.setSigningKey(signingKey);
return converter;
}
@Bean
public TokenStore tokenStore() {
return new JwtTokenStore(accessTokenConverter());
}
@Bean
public DefaultTokenServices tokenServices() {
DefaultTokenServices defaultTokenServices = new DefaultTokenServices();
defaultTokenServices.setTokenStore(tokenStore());
defaultTokenServices.setSupportRefreshToken(true);
return defaultTokenServices;
}
@Override
public void configure(ClientDetailsServiceConfigurer configurer) throws Exception {
configurer.inMemory().withClient(clientId).secret(signingKey).autoApprove(true)
.authorizedGrantTypes(grantTypeAuthorizationCode, grantTypePassword, grantTypeRefreshToken)
.scopes(scopeWeb, scopeMobile).resourceIds(resourcesIdBuySell, resourcesIdGateway, resourcesIdUpload);
}
@Override
public void configure(AuthorizationServerEndpointsConfigurer endpoints) throws Exception {
endpoints.tokenStore(tokenStore()).accessTokenConverter(accessTokenConverter())
.authenticationManager(authenticationManager);
}
}
@Configuration
public class SecurityConfig extends WebSecurityConfigurerAdapter {
@Bean
public PasswordEncoder passwordEncoder() {
return new BCryptPasswordEncoder();
}
@Override
@Bean
public AuthenticationManager authenticationManagerBean() throws Exception {
return super.authenticationManagerBean();
}
@Bean
public UserDetailsService userDetailsService() {
return new UserServiceImpl();
}
@Override
protected void configure(AuthenticationManagerBuilder auth) throws Exception {
auth.userDetailsService(userDetailsServiceBean()).passwordEncoder(passwordEncoder());
}
@Override
protected void configure(HttpSecurity http) throws Exception {
http.authorizeRequests().antMatchers("/oauth/token", "/oauth/authorize", "/oauth/confirm_access").permitAll()
.anyRequest().authenticated().and().csrf().disable().cors().and()
.userDetailsService(userDetailsService());
}
@Override
public void configure(WebSecurity web) throws Exception {
web.ignoring().antMatchers(HttpMethod.OPTIONS);
}
}
1 ответ
Зависит от того, какой OAuthServer вы используете. Лично я использую серверную часть ASP.NET Core с IdentityServer, и она поддерживает внешние логины https://identityserver4.readthedocs.io/en/release/quickstarts/4_external_authentication.html
Я также попробовал это на nodeJS, используя passportJS http://www.passportjs.org/docs/
Оба из этих OAuthServers имеют поддержку Facebook и Google, вам просто нужно связать свои претензии на основе данных, которые вы получили с Facebook или Google.