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


Java ProtectedResourceDetails類代碼示例

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


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

示例1: testGetRestTemplate_ReturnsOauthTemplate

import org.springframework.security.oauth.consumer.ProtectedResourceDetails; //導入依賴的package包/類
@Test
public void testGetRestTemplate_ReturnsOauthTemplate() throws Exception {
	//When
	RestTemplate restTemplate = userSyncRestTemplateFactory.getOAuthRestTemplate("some-key", "some-secret");

	//Then
	assertThat(restTemplate).isInstanceOf(OAuthRestTemplate.class);
	OAuthRestTemplate oauthRestTemplate = (OAuthRestTemplate) restTemplate;

   //Then
	ProtectedResourceDetails resource = oauthRestTemplate.getResource();
	assertThat(resource.getConsumerKey()).isEqualTo("some-key");
	assertThat(resource.getSharedSecret())
			.isInstanceOf(SharedConsumerSecretImpl.class)
			.hasFieldOrPropertyWithValue("consumerSecret", "some-secret");
}
 
開發者ID:AppDirect,項目名稱:service-integration-sdk,代碼行數:17,代碼來源:UserSyncRestTemplateFactoryImplTest.java

示例2: getUnauthorizedRequestToken

import org.springframework.security.oauth.consumer.ProtectedResourceDetails; //導入依賴的package包/類
public OAuthConsumerToken getUnauthorizedRequestToken(ProtectedResourceDetails details, String callback) throws OAuthRequestFailedException {  
  URL requestTokenURL;
  try {
    requestTokenURL = new URL(details.getRequestTokenURL());
  }
  catch (MalformedURLException e) {
    throw new IllegalStateException("Malformed URL for obtaining a request token.", e);
  }

  String httpMethod = details.getRequestTokenHttpMethod();

  Map<String, String> additionalParameters = new TreeMap<String, String>();
  if (details.isUse10a()) {
    additionalParameters.put(OAuthConsumerParameter.oauth_callback.toString(), callback);
  }
  Map<String, String> specifiedParams = details.getAdditionalParameters();
  if (specifiedParams != null) {
    additionalParameters.putAll(specifiedParams);
  }
  return getTokenFromProvider(details, requestTokenURL, httpMethod, null, additionalParameters);
}
 
開發者ID:jungyang,項目名稱:oauth-client-master,代碼行數:22,代碼來源:CoreOAuthConsumerSupport.java

示例3: getAccessToken

import org.springframework.security.oauth.consumer.ProtectedResourceDetails; //導入依賴的package包/類
public OAuthConsumerToken getAccessToken(ProtectedResourceDetails details, OAuthConsumerToken requestToken, String verifier) {
  URL accessTokenURL;
  try {
    accessTokenURL = new URL(details.getAccessTokenURL());
  }
  catch (MalformedURLException e) {
    throw new IllegalStateException("Malformed URL for obtaining an access token.", e);
  }

  String httpMethod = details.getAccessTokenHttpMethod();

  Map<String, String> additionalParameters = new TreeMap<String, String>();
  if (details.isUse10a()) {
    if (verifier == null) {
      throw new UnverifiedRequestTokenException("Unverified request token: " + requestToken);
    }
    additionalParameters.put(OAuthConsumerParameter.oauth_verifier.toString(), verifier);
  }
  Map<String, String> specifiedParams = details.getAdditionalParameters();
  if (specifiedParams != null) {
    additionalParameters.putAll(specifiedParams);
  }
  return getTokenFromProvider(details, accessTokenURL, httpMethod, requestToken, additionalParameters);
}
 
開發者ID:jungyang,項目名稱:oauth-client-master,代碼行數:25,代碼來源:CoreOAuthConsumerSupport.java

示例4: getUserAuthorizationRedirectURL

import org.springframework.security.oauth.consumer.ProtectedResourceDetails; //導入依賴的package包/類
/**
 * Get the URL to which to redirect the user for authorization of protected resources.
 *
 * @param details	  The resource for which to get the authorization url.
 * @param requestToken The request token.
 * @param callbackURL  The callback URL.
 * @return The URL.
 */
protected String getUserAuthorizationRedirectURL(ProtectedResourceDetails details, OAuthConsumerToken requestToken, String callbackURL) {
	try {
		String baseURL = details.getUserAuthorizationURL();
		StringBuilder builder = new StringBuilder(baseURL);
		char appendChar = baseURL.indexOf('?') < 0 ? '?' : '&';
		builder.append(appendChar).append("oauth_token=");
		builder.append(URLEncoder.encode(requestToken.getValue(), "UTF-8"));
		if (!details.isUse10a()) {
			builder.append('&').append("oauth_callback=");
			builder.append(URLEncoder.encode(callbackURL, "UTF-8"));
		}
		return builder.toString();
	}
	catch (UnsupportedEncodingException e) {
		throw new IllegalStateException(e);
	}
}
 
開發者ID:jungyang,項目名稱:oauth-client-master,代碼行數:26,代碼來源:OAuthConsumerContextFilter.java

示例5: readProtectedResource

import org.springframework.security.oauth.consumer.ProtectedResourceDetails; //導入依賴的package包/類
public InputStream readProtectedResource(URL url, OAuthConsumerToken accessToken, String httpMethod) throws OAuthRequestFailedException {
  if (accessToken == null) {
    throw new OAuthRequestFailedException("A valid access token must be supplied.");
  }

  ProtectedResourceDetails resourceDetails = getProtectedResourceDetailsService().loadProtectedResourceDetailsById(accessToken.getResourceId());
  if ((!resourceDetails.isAcceptsAuthorizationHeader()) && !"POST".equalsIgnoreCase(httpMethod) && !"PUT".equalsIgnoreCase(httpMethod)) {
    throw new IllegalArgumentException("Protected resource " + resourceDetails.getId() + " cannot be accessed with HTTP method " +
      httpMethod + " because the OAuth provider doesn't accept the OAuth Authorization header.");
  }

  return readResource(resourceDetails, url, httpMethod, accessToken, resourceDetails.getAdditionalParameters(), null);
}
 
開發者ID:jungyang,項目名稱:oauth-client-master,代碼行數:14,代碼來源:CoreOAuthConsumerSupport.java

示例6: getAuthorizationHeader

import org.springframework.security.oauth.consumer.ProtectedResourceDetails; //導入依賴的package包/類
public String getAuthorizationHeader(ProtectedResourceDetails details, OAuthConsumerToken accessToken, URL url, String httpMethod, Map<String, String> additionalParameters) {
  if (!details.isAcceptsAuthorizationHeader()) {
    return null;
  }
  else {
    Map<String, Set<CharSequence>> oauthParams = loadOAuthParameters(details, url, accessToken, httpMethod, additionalParameters);
    String realm = details.getAuthorizationHeaderRealm();

    StringBuilder builder = new StringBuilder("OAuth ");
    boolean writeComma = false;
    if (realm != null) { //realm is optional.
      builder.append("realm=\"").append(realm).append('"');
      writeComma = true;
    }

    for (Map.Entry<String, Set<CharSequence>> paramValuesEntry : oauthParams.entrySet()) {
      Set<CharSequence> paramValues = paramValuesEntry.getValue();
      CharSequence paramValue = findValidHeaderValue(paramValues);
      if (paramValue != null) {
        if (writeComma) {
          builder.append(", ");
        }

        builder.append(paramValuesEntry.getKey()).append("=\"").append(oauthEncode(paramValue.toString())).append('"');
        writeComma = true;
      }
    }

    return builder.toString();
  }
}
 
開發者ID:jungyang,項目名稱:oauth-client-master,代碼行數:32,代碼來源:CoreOAuthConsumerSupport.java

示例7: OAuthRestTemplate

import org.springframework.security.oauth.consumer.ProtectedResourceDetails; //導入依賴的package包/類
public OAuthRestTemplate(ClientHttpRequestFactory requestFactory, ProtectedResourceDetails resource) {
  super();
  if (resource == null) {
    throw new IllegalArgumentException("An OAuth resource must be supplied.");
  }
  if (support == null) {
    throw new IllegalArgumentException("OAuth support must be supplied.");
  }

  this.resource = resource;
  setRequestFactory(requestFactory);
}
 
開發者ID:jungyang,項目名稱:oauth-client-master,代碼行數:13,代碼來源:OAuthRestTemplate.java

示例8: OAuthClientHttpRequestFactory

import org.springframework.security.oauth.consumer.ProtectedResourceDetails; //導入依賴的package包/類
public OAuthClientHttpRequestFactory(ClientHttpRequestFactory delegate, ProtectedResourceDetails resource, OAuthConsumerSupport support) {
  this.delegate = delegate;
  this.resource = resource;
  this.support = support;

  if (delegate == null) {
    throw new IllegalArgumentException("A delegate must be supplied for an OAuth2ClientHttpRequestFactory.");
  }
  if (resource == null) {
    throw new IllegalArgumentException("A resource must be supplied for an OAuth2ClientHttpRequestFactory.");
  }
}
 
開發者ID:jungyang,項目名稱:oauth-client-master,代碼行數:13,代碼來源:OAuthClientHttpRequestFactory.java

示例9: OAuthOverHttpsURLStreamHandler

import org.springframework.security.oauth.consumer.ProtectedResourceDetails; //導入依賴的package包/類
public OAuthOverHttpsURLStreamHandler(ProtectedResourceDetails resourceDetails, OAuthConsumerToken accessToken, OAuthConsumerSupport support, String httpMethod, Map<String, String> additionalParameters) {
  this.resourceDetails = resourceDetails;
  this.accessToken = accessToken;
  this.support = support;
  this.httpMethod = httpMethod;
  this.additionalParameters = additionalParameters;
}
 
開發者ID:jungyang,項目名稱:oauth-client-master,代碼行數:8,代碼來源:OAuthOverHttpsURLStreamHandler.java

示例10: OAuthOverHttpURLStreamHandler

import org.springframework.security.oauth.consumer.ProtectedResourceDetails; //導入依賴的package包/類
public OAuthOverHttpURLStreamHandler(ProtectedResourceDetails resourceDetails, OAuthConsumerToken accessToken, OAuthConsumerSupport support, String httpMethod, Map<String, String> additionalParameters) {
  this.resourceDetails = resourceDetails;
  this.accessToken = accessToken;
  this.support = support;
  this.httpMethod = httpMethod;
  this.additionalParameters = additionalParameters;
}
 
開發者ID:jungyang,項目名稱:oauth-client-master,代碼行數:8,代碼來源:OAuthOverHttpURLStreamHandler.java

示例11: checkForResourceThatNeedsAuthorization

import org.springframework.security.oauth.consumer.ProtectedResourceDetails; //導入依賴的package包/類
/**
 * Check the given exception for the resource that needs authorization. If the exception was not thrown because a resource needed authorization, then rethrow
 * the exception.
 *
 * @param ex The exception.
 * @return The resource that needed authorization (never null).
 */
protected ProtectedResourceDetails checkForResourceThatNeedsAuthorization(Exception ex) throws ServletException, IOException {
	Throwable[] causeChain = getThrowableAnalyzer().determineCauseChain(ex);
	AccessTokenRequiredException ase = (AccessTokenRequiredException) getThrowableAnalyzer().getFirstThrowableOfType(AccessTokenRequiredException.class, causeChain);
	ProtectedResourceDetails resourceThatNeedsAuthorization;
	if (ase != null) {
		resourceThatNeedsAuthorization = ase.getResource();
		if (resourceThatNeedsAuthorization == null) {
			throw new OAuthRequestFailedException(ase.getMessage());
		}
	}
	else {
		// Rethrow ServletExceptions and RuntimeExceptions as-is
		if (ex instanceof ServletException) {
			throw (ServletException) ex;
		}
		if (ex instanceof IOException) {
			throw (IOException) ex;
		}
		else if (ex instanceof RuntimeException) {
			throw (RuntimeException) ex;
		}

		// Wrap other Exceptions. These are not expected to happen
		throw new RuntimeException(ex);
	}
	return resourceThatNeedsAuthorization;
}
 
開發者ID:jungyang,項目名稱:oauth-client-master,代碼行數:35,代碼來源:OAuthConsumerContextFilter.java

示例12: createInstance

import org.springframework.security.oauth.consumer.ProtectedResourceDetails; //導入依賴的package包/類
@Override
protected ProtectedResourceDetailsService createInstance() throws Exception {
  Map<String, ProtectedResourceDetails> detailsMap = BeanFactoryUtils.beansOfTypeIncludingAncestors((ListableBeanFactory) getBeanFactory(),
                                                                                                         ProtectedResourceDetails.class);
  InMemoryProtectedResourceDetailsService service = new InMemoryProtectedResourceDetailsService();
  service.setResourceDetailsStore(detailsMap);
  return service;
}
 
開發者ID:jungyang,項目名稱:oauth-client-master,代碼行數:9,代碼來源:ProtectedResourceDetailsServiceFactoryBean.java

示例13: testGetAuthorizationHeader

import org.springframework.security.oauth.consumer.ProtectedResourceDetails; //導入依賴的package包/類
/**
 * test getAuthorizationHeader
 */
@Test
public void testGetAuthorizationHeader() throws Exception {
	final TreeMap<String, Set<CharSequence>> params = new TreeMap<String, Set<CharSequence>>();
	CoreOAuthConsumerSupport support = new CoreOAuthConsumerSupport() {
		@Override
		protected Map<String, Set<CharSequence>> loadOAuthParameters(ProtectedResourceDetails details,
				URL requestURL, OAuthConsumerToken requestToken, String httpMethod,
				Map<String, String> additionalParameters) {
			return params;
		}
	};
	URL url = new URL("https://myhost.com/somepath?with=some&query=params&too");
	OAuthConsumerToken token = new OAuthConsumerToken();

	when(details.isAcceptsAuthorizationHeader()).thenReturn(false);
	assertNull(support.getAuthorizationHeader(details, token, url, "POST", null));

	params.put("with", Collections.singleton((CharSequence) "some"));
	params.put("query", Collections.singleton((CharSequence) "params"));
	params.put("too", null);
	when(details.isAcceptsAuthorizationHeader()).thenReturn(true);
	when(details.getAuthorizationHeaderRealm()).thenReturn("myrealm");
	assertEquals("OAuth realm=\"myrealm\", query=\"params\", with=\"some\"",
			support.getAuthorizationHeader(details, token, url, "POST", null));

	params.put(OAuthConsumerParameter.oauth_consumer_key.toString(), Collections.singleton((CharSequence) "mykey"));
	params.put(OAuthConsumerParameter.oauth_nonce.toString(), Collections.singleton((CharSequence) "mynonce"));
	params.put(OAuthConsumerParameter.oauth_timestamp.toString(), Collections.singleton((CharSequence) "myts"));
	when(details.isAcceptsAuthorizationHeader()).thenReturn(true);
	when(details.getAuthorizationHeaderRealm()).thenReturn("myrealm");
	assertEquals(
			"OAuth realm=\"myrealm\", oauth_consumer_key=\"mykey\", oauth_nonce=\"mynonce\", oauth_timestamp=\"myts\", query=\"params\", with=\"some\"",
			support.getAuthorizationHeader(details, token, url, "POST", null));
}
 
開發者ID:jungyang,項目名稱:oauth-client-master,代碼行數:38,代碼來源:CoreOAuthConsumerSupportTests.java

示例14: getResource

import org.springframework.security.oauth.consumer.ProtectedResourceDetails; //導入依賴的package包/類
public ProtectedResourceDetails getResource() {
  return resource;
}
 
開發者ID:jungyang,項目名稱:oauth-client-master,代碼行數:4,代碼來源:OAuthRestTemplate.java

示例15: getHttpStreamHandler

import org.springframework.security.oauth.consumer.ProtectedResourceDetails; //導入依賴的package包/類
public URLStreamHandler getHttpStreamHandler(ProtectedResourceDetails resourceDetails, OAuthConsumerToken accessToken, OAuthConsumerSupport support, String httpMethod, Map<String, String> additionalParameters) {
  return new OAuthOverHttpURLStreamHandler(resourceDetails, accessToken, support, httpMethod, additionalParameters);
}
 
開發者ID:jungyang,項目名稱:oauth-client-master,代碼行數:4,代碼來源:DefaultOAuthURLStreamHandlerFactory.java


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