當前位置: 首頁>>代碼示例>>Java>>正文


Java ClientDetailsService類代碼示例

本文整理匯總了Java中org.springframework.security.oauth2.provider.ClientDetailsService的典型用法代碼示例。如果您正苦於以下問題:Java ClientDetailsService類的具體用法?Java ClientDetailsService怎麽用?Java ClientDetailsService使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。


ClientDetailsService類屬於org.springframework.security.oauth2.provider包,在下文中一共展示了ClientDetailsService類的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: getCustomizedTokenGranters

import org.springframework.security.oauth2.provider.ClientDetailsService; //導入依賴的package包/類
private List<TokenGranter> getCustomizedTokenGranters() {
    AuthorizationServerTokenServices tokenServices = tokenServices();
    ClientDetailsService clientDetails = clientDetailsService();
    AuthorizationCodeServices authorizationCodeServices = authorizationCodeServices();
    OAuth2RequestFactory requestFactory = new DefaultOAuth2RequestFactory(clientDetails);

    AuthorizationCodeTokenGranter authorizationCodeTokenGranter = new AuthorizationCodeTokenGranter(tokenServices, authorizationCodeServices, clientDetails, requestFactory);
    RefreshTokenGranter refreshTokenGranter = new RefreshTokenGranter(tokenServices, clientDetails, requestFactory);
    ImplicitTokenGranter implicit = new ImplicitTokenGranter(tokenServices, clientDetails, requestFactory);
    ClientCredentialsTokenGranter clientCredentialsTokenGranter = new ClientCredentialsTokenGranter(tokenServices, clientDetails, requestFactory);
    clientCredentialsTokenGranter.setAllowRefresh(true);//custom config, see AuthorizationServerEndpointsConfigurer.getDefaultTokenGranters

    List<TokenGranter> tokenGranters = new ArrayList<>();
    tokenGranters.add(authorizationCodeTokenGranter);
    tokenGranters.add(refreshTokenGranter);
    tokenGranters.add(implicit);
    tokenGranters.add(clientCredentialsTokenGranter);
    if (authenticationManager != null) {
        tokenGranters.add(new ResourceOwnerPasswordTokenGranter(authenticationManager, tokenServices, clientDetails, requestFactory));
    }

    return tokenGranters;
}
 
開發者ID:openmg,項目名稱:metagraph-auth,代碼行數:24,代碼來源:AuthorizationServerConfigurer.java

示例2: clientDetailsService

import org.springframework.security.oauth2.provider.ClientDetailsService; //導入依賴的package包/類
private ClientDetailsService clientDetailsService() throws Exception {
      // @formatter:off
return new InMemoryClientDetailsServiceBuilder()
	.withClient("clientapp")
	    .authorizedGrantTypes("password", "refresh_token")
	    .authorities("USER")
	    .scopes("read", "write")
	    .secret("123456")
	.and()
	.withClient("clientapp2")
	    .authorizedGrantTypes("client_credentials")
	    .authorities("USER")
	    .scopes("read", "write")
	    .secret("123456")
	.and()
	.withClient("clientapp3")
	    .authorizedGrantTypes("authorization_code")
	    .authorities("USER")
	    .redirectUris(
                   "http://localhost:5000/login.html",
                   "http://localhost:5000/diff_login.html")
	    .scopes("read", "write")
	    .secret("123456")
	.and().build();
// @formatter:on
  }
 
開發者ID:petrbouda,項目名稱:joyrest,代碼行數:27,代碼來源:InMemoryOAuthConfiguration.java

示例3: OAuthConfig

import org.springframework.security.oauth2.provider.ClientDetailsService; //導入依賴的package包/類
public OAuthConfig() throws Exception {
	
	ClientDetailsService csvc = new InMemoryClientDetailsServiceBuilder()
					.withClient("mobile").authorizedGrantTypes("password")
					.authorities("ROLE_CLIENT", "ROLE_TRUSTED_CLIENT")
					.scopes("read","write").resourceIds("prublisher")
					.accessTokenValiditySeconds(3600).and().build();
	
	UserDetailsService svc = new InMemoryUserDetailsManager(
			Arrays.asList(
							User.create("publisher", "publisher", MobileClient.ROLE_PUBLISHER),
							User.create("subscriber", "subscriber", MobileClient.ROLE_SUBSCRIBER)));
	
	combinedService_ = new ClientAndUserDetailsService(csvc,svc);
}
 
開發者ID:kflauri2312lffds,項目名稱:Android_watch_magpie,代碼行數:16,代碼來源:OAuth2SecurityConfiguration.java

示例4: clientDetailsService

import org.springframework.security.oauth2.provider.ClientDetailsService; //導入依賴的package包/類
@Bean
ClientDetailsService clientDetailsService() {
    return clientId -> clientRepository.findByClientId(clientId)
        .map(client -> {
            BaseClientDetails details = new BaseClientDetails(
                    client.getClientId(),
                    null,
                    client.getScopes(),
                    client.getAuthorizedGrantTypes(),
                    client.getAuthorities(),
                    client.getRegisteredRedirectUri()
            );
            details.setClientSecret(client.getSecret());
            details.setAutoApproveScopes(Arrays.asList(client.getAutoApproveScopes().split(",")));
            details.setAccessTokenValiditySeconds(1800);  // 30mn Token < 1h RefreshToken!
            details.setRefreshTokenValiditySeconds(3600);
            return details;
        })
        .orElseThrow(() -> new ClientRegistrationException(String.format("no client %s registered", clientId)));
}
 
開發者ID:javaguru,項目名稱:tcloud-microservices,代碼行數:21,代碼來源:AuthServiceApplication.java

示例5: testDefaultConfiguration

import org.springframework.security.oauth2.provider.ClientDetailsService; //導入依賴的package包/類
@Test
public void testDefaultConfiguration() {
	this.context = new AnnotationConfigEmbeddedWebApplicationContext();
	this.context.register(AuthorizationAndResourceServerConfiguration.class,
			MinimalSecureWebApplication.class);
	this.context.refresh();
	this.context.getBean(AUTHORIZATION_SERVER_CONFIG);
	this.context.getBean(RESOURCE_SERVER_CONFIG);
	this.context.getBean(OAuth2MethodSecurityConfiguration.class);
	ClientDetails config = this.context.getBean(BaseClientDetails.class);
	AuthorizationEndpoint endpoint = this.context
			.getBean(AuthorizationEndpoint.class);
	UserApprovalHandler handler = (UserApprovalHandler) ReflectionTestUtils
			.getField(endpoint, "userApprovalHandler");
	ClientDetailsService clientDetailsService = this.context
			.getBean(ClientDetailsService.class);
	ClientDetails clientDetails = clientDetailsService
			.loadClientByClientId(config.getClientId());
	assertThat(AopUtils.isJdkDynamicProxy(clientDetailsService), equalTo(true));
	assertThat(AopUtils.getTargetClass(clientDetailsService).getName(),
			is(equalTo(InMemoryClientDetailsService.class.getName())));
	assertThat(handler instanceof ApprovalStoreUserApprovalHandler, equalTo(true));
	assertThat(clientDetails, equalTo(config));
	verifyAuthentication(config);
}
 
開發者ID:Nephilim84,項目名稱:contestparser,代碼行數:26,代碼來源:OAuth2AutoConfigurationTests.java

示例6: testClientSpecificRefreshTokenExpiry

import org.springframework.security.oauth2.provider.ClientDetailsService; //導入依賴的package包/類
@Test
public void testClientSpecificRefreshTokenExpiry() throws Exception {
	getTokenServices().setRefreshTokenValiditySeconds(1000);
	getTokenServices().setClientDetailsService(new ClientDetailsService() {
		public ClientDetails loadClientByClientId(String clientId)
				throws OAuth2Exception {
			BaseClientDetails client = new BaseClientDetails();
			client.setRefreshTokenValiditySeconds(100);
			client.setAuthorizedGrantTypes(Arrays.asList(
					"authorization_code", "refresh_token"));
			return client;
		}
	});
	OAuth2AccessToken accessToken = getTokenServices().createAccessToken(
			createAuthentication());
	DefaultExpiringOAuth2RefreshToken refreshToken = (DefaultExpiringOAuth2RefreshToken) accessToken
			.getRefreshToken();
	Date expectedExpiryDate = new Date(
			System.currentTimeMillis() + 102 * 1000L);
	assertTrue(expectedExpiryDate.after(refreshToken.getExpiration()));
}
 
開發者ID:jungyang,項目名稱:oauth-client-master,代碼行數:22,代碼來源:AbstractTestDefaultTokenServices.java

示例7: testClientSpecificRefreshTokenExpiry

import org.springframework.security.oauth2.provider.ClientDetailsService; //導入依賴的package包/類
@Test
public void testClientSpecificRefreshTokenExpiry() throws Exception {
	services.setRefreshTokenValiditySeconds(1000);
	services.setClientDetailsService(new ClientDetailsService() {
		public ClientDetails loadClientByClientId(String clientId) throws OAuth2Exception {
			BaseClientDetails client = new BaseClientDetails();
			client.setRefreshTokenValiditySeconds(100);
			client.setAuthorizedGrantTypes(Arrays.asList("authorization_code", "refresh_token"));
			return client;
		}
	});
	OAuth2AccessToken accessToken = services.createAccessToken(createAuthentication());
	DefaultExpiringOAuth2RefreshToken refreshToken = (DefaultExpiringOAuth2RefreshToken) accessToken
			.getRefreshToken();
	Date expectedExpiryDate = new Date(System.currentTimeMillis() + 102 * 1000L);
	assertTrue(expectedExpiryDate.after(refreshToken.getExpiration()));
}
 
開發者ID:jungyang,項目名稱:oauth-client-master,代碼行數:18,代碼來源:JwtTokenServicesTests.java

示例8: testNoRefreshTokenIfNotAuthorized

import org.springframework.security.oauth2.provider.ClientDetailsService; //導入依賴的package包/類
@Test
public void testNoRefreshTokenIfNotAuthorized() throws Exception {
	// create access token
	getTokenServices().setAccessTokenValiditySeconds(1);
	getTokenServices().setClientDetailsService(new ClientDetailsService() {
		public ClientDetails loadClientByClientId(String clientId) throws OAuth2Exception {
			BaseClientDetails client = new BaseClientDetails();
			client.setAccessTokenValiditySeconds(1);
			client.setAuthorizedGrantTypes(Arrays.asList("authorization_code"));
			return client;
		}
	});
	OAuth2Authentication expectedAuthentication = new OAuth2Authentication(RequestTokenFactory.createOAuth2Request(null, "id", null, false, Collections.singleton("read"), null, null, null, null), new TestAuthentication("test2", false));
	DefaultOAuth2AccessToken token = (DefaultOAuth2AccessToken) getTokenServices().createAccessToken(
			expectedAuthentication);
	assertNull(token.getRefreshToken());
}
 
開發者ID:jungyang,項目名稱:oauth-client-master,代碼行數:18,代碼來源:DefaultTokenServicesWithInMemoryTests.java

示例9: init

import org.springframework.security.oauth2.provider.ClientDetailsService; //導入依賴的package包/類
@Before
public void init() throws Exception {
	client = new BaseClientDetails();
	client.setRegisteredRedirectUri(Collections.singleton("http://anywhere.com"));
	client.setAuthorizedGrantTypes(Arrays.asList("authorization_code", "implicit"));
	endpoint.setClientDetailsService(new ClientDetailsService() {
		public ClientDetails loadClientByClientId(String clientId) throws OAuth2Exception {
			return client;
		}
	});
	endpoint.setTokenGranter(new TokenGranter() {
		public OAuth2AccessToken grant(String grantType, TokenRequest tokenRequest) {
			return null;
		}
	});
	endpoint.setRedirectResolver(new DefaultRedirectResolver());
	endpoint.afterPropertiesSet();
}
 
開發者ID:jungyang,項目名稱:oauth-client-master,代碼行數:19,代碼來源:AuthorizationEndpointTests.java

示例10: testDefaultConfiguration

import org.springframework.security.oauth2.provider.ClientDetailsService; //導入依賴的package包/類
@Test
public void testDefaultConfiguration() {
	this.context = new AnnotationConfigServletWebServerApplicationContext();
	this.context.register(AuthorizationAndResourceServerConfiguration.class,
			MinimalSecureWebApplication.class);
	this.context.refresh();
	this.context.getBean(AUTHORIZATION_SERVER_CONFIG);
	this.context.getBean(RESOURCE_SERVER_CONFIG);
	this.context.getBean(OAuth2MethodSecurityConfiguration.class);
	ClientDetails config = this.context.getBean(BaseClientDetails.class);
	AuthorizationEndpoint endpoint = this.context
			.getBean(AuthorizationEndpoint.class);
	UserApprovalHandler handler = (UserApprovalHandler) ReflectionTestUtils
			.getField(endpoint, "userApprovalHandler");
	ClientDetailsService clientDetailsService = this.context
			.getBean(ClientDetailsService.class);
	ClientDetails clientDetails = clientDetailsService
			.loadClientByClientId(config.getClientId());
	assertThat(AopUtils.isJdkDynamicProxy(clientDetailsService)).isTrue();
	assertThat(AopUtils.getTargetClass(clientDetailsService).getName())
			.isEqualTo(InMemoryClientDetailsService.class.getName());
	assertThat(handler).isInstanceOf(ApprovalStoreUserApprovalHandler.class);
	assertThat(clientDetails).isEqualTo(config);
	verifyAuthentication(config);
	assertThat(this.context.getBeanNamesForType(OAuth2RestOperations.class))
			.isEmpty();
}
 
開發者ID:spring-projects,項目名稱:spring-security-oauth2-boot,代碼行數:28,代碼來源:OAuth2AutoConfigurationTests.java

示例11: CustomResourceOwnerPasswordTokenGranter

import org.springframework.security.oauth2.provider.ClientDetailsService; //導入依賴的package包/類
public CustomResourceOwnerPasswordTokenGranter(
    AuthenticationManager authenticationManager,
    AuthorizationServerTokenServices tokenServices,
    ClientDetailsService clientDetailsService,
    OAuth2RequestFactory requestFactory) {
  this(authenticationManager, tokenServices, clientDetailsService,
      requestFactory, GRANT_TYPE);
}
 
開發者ID:gdong42,項目名稱:spring-auth-example,代碼行數:9,代碼來源:CustomResourceOwnerPasswordTokenGranter.java

示例12: ClientAndUserDetailsService

import org.springframework.security.oauth2.provider.ClientDetailsService; //導入依賴的package包/類
public ClientAndUserDetailsService(ClientDetailsService clients,
		UserDetailsService users) {
	super();
	clients_ = clients;
	users_ = users;
	clientDetailsWrapper_ = new ClientDetailsUserDetailsService(clients_);
}
 
開發者ID:kflauri2312lffds,項目名稱:Android_watch_magpie,代碼行數:8,代碼來源:ClientAndUserDetailsService.java

示例13: configure

import org.springframework.security.oauth2.provider.ClientDetailsService; //導入依賴的package包/類
@Override
protected void configure(final HttpSecurity http) throws Exception {
    AuthorizationServerSecurityConfigurer configurer = new AuthorizationServerSecurityConfigurer();
    FrameworkEndpointHandlerMapping handlerMapping = endpoints.oauth2EndpointHandlerMapping();
    http.setSharedObject(FrameworkEndpointHandlerMapping.class, handlerMapping);
    configure(configurer);
    http.apply(configurer);
    String tokenEndpointPath = handlerMapping.getServletPath("/oauth/token");
    String tokenKeyPath = handlerMapping.getServletPath("/oauth/token_key");
    String checkTokenPath = handlerMapping.getServletPath("/oauth/check_token");
    String revokeTokenPath = handlerMapping.getServletPath("/oauth/revoke");
    if (!endpoints.getEndpointsConfigurer().isUserDetailsServiceOverride()) {
        UserDetailsService userDetailsService = http.getSharedObject(UserDetailsService.class);
        endpoints.getEndpointsConfigurer().userDetailsService(userDetailsService);
    }
    // @formatter:off
    http
            .authorizeRequests()
            // Per the OAuth2 spec, we should only allow POST to the token endpoint.
            // See: https://github.com/spring-projects/spring-security-oauth/issues/327
            .antMatchers(HttpMethod.GET, tokenEndpointPath).denyAll()
            .antMatchers(HttpMethod.PUT, tokenEndpointPath).denyAll()
            .antMatchers(HttpMethod.PATCH, tokenEndpointPath).denyAll()
            .antMatchers(HttpMethod.DELETE, tokenEndpointPath).denyAll()
            .and()
            .authorizeRequests()
            .antMatchers(HttpMethod.OPTIONS, "**").permitAll()
            .antMatchers(tokenEndpointPath).fullyAuthenticated()
            .antMatchers(tokenKeyPath).access(configurer.getTokenKeyAccess())
            .antMatchers(checkTokenPath).access(configurer.getCheckTokenAccess())
            .antMatchers(revokeTokenPath).access(configurer.getCheckTokenAccess())
            .and()
            .requestMatchers()
            .antMatchers(tokenEndpointPath, tokenKeyPath, checkTokenPath, revokeTokenPath)
            .and()
            .sessionManagement().sessionCreationPolicy(SessionCreationPolicy.NEVER);
    // @formatter:on
    http.setSharedObject(ClientDetailsService.class, clientDetailsService);
}
 
開發者ID:gravitee-io,項目名稱:graviteeio-access-management,代碼行數:40,代碼來源:CustomAuthorizationServerSecurityConfiguration.java

示例14: AuthorizationServerConfig

import org.springframework.security.oauth2.provider.ClientDetailsService; //導入依賴的package包/類
@Autowired
public AuthorizationServerConfig(AuthenticationManager authenticationManager,
                                 ClientDetailsService clientDetailsService, UserDetailsService userDetailsService) {
    this.authenticationManager = authenticationManager;
    this.clientDetailsService = clientDetailsService;
    this.userDetailsService = userDetailsService;
}
 
開發者ID:javaguru,項目名稱:tcloud-microservices,代碼行數:8,代碼來源:AuthServiceApplication.java

示例15: testDefaultConfiguration

import org.springframework.security.oauth2.provider.ClientDetailsService; //導入依賴的package包/類
@Test
public void testDefaultConfiguration() {
	this.context = new AnnotationConfigEmbeddedWebApplicationContext();
	this.context.register(AuthorizationAndResourceServerConfiguration.class,
			MinimalSecureWebApplication.class);
	this.context.refresh();
	this.context.getBean(AUTHORIZATION_SERVER_CONFIG);
	this.context.getBean(RESOURCE_SERVER_CONFIG);
	this.context.getBean(OAuth2MethodSecurityConfiguration.class);
	ClientDetails config = this.context.getBean(BaseClientDetails.class);
	AuthorizationEndpoint endpoint = this.context
			.getBean(AuthorizationEndpoint.class);
	UserApprovalHandler handler = (UserApprovalHandler) ReflectionTestUtils
			.getField(endpoint, "userApprovalHandler");
	ClientDetailsService clientDetailsService = this.context
			.getBean(ClientDetailsService.class);
	ClientDetails clientDetails = clientDetailsService
			.loadClientByClientId(config.getClientId());
	assertThat(AopUtils.isJdkDynamicProxy(clientDetailsService)).isTrue();
	assertThat(AopUtils.getTargetClass(clientDetailsService).getName())
			.isEqualTo(InMemoryClientDetailsService.class.getName());
	assertThat(handler).isInstanceOf(ApprovalStoreUserApprovalHandler.class);
	assertThat(clientDetails).isEqualTo(config);
	verifyAuthentication(config);
	assertThat(this.context.getBeanNamesForType(OAuth2RestOperations.class))
			.isEmpty();
}
 
開發者ID:vikrammane23,項目名稱:https-github.com-g0t4-jenkins2-course-spring-boot,代碼行數:28,代碼來源:OAuth2AutoConfigurationTests.java


注:本文中的org.springframework.security.oauth2.provider.ClientDetailsService類示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。