本文整理匯總了Java中org.springframework.security.oauth2.common.OAuth2AccessToken.getValue方法的典型用法代碼示例。如果您正苦於以下問題:Java OAuth2AccessToken.getValue方法的具體用法?Java OAuth2AccessToken.getValue怎麽用?Java OAuth2AccessToken.getValue使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類org.springframework.security.oauth2.common.OAuth2AccessToken
的用法示例。
在下文中一共展示了OAuth2AccessToken.getValue方法的11個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。
示例1: acquireAccessToken
import org.springframework.security.oauth2.common.OAuth2AccessToken; //導入方法依賴的package包/類
protected OAuth2AccessToken acquireAccessToken(OAuth2ProtectedResourceDetails resource)
throws UserRedirectRequiredException {
AccessTokenRequest tokenRequest = oAuth2ClientContext.getAccessTokenRequest();
if (tokenRequest == null) {
throw new AccessTokenRequiredException(
"Cannot find valid context on request for resource '" + resource.getId() + "'.", resource);
}
String stateKey = tokenRequest.getStateKey();
if (stateKey != null) {
tokenRequest.setPreservedState(oAuth2ClientContext.removePreservedState(stateKey));
}
OAuth2AccessToken existingToken = oAuth2ClientContext.getAccessToken();
if (existingToken != null) {
oAuth2ClientContext.setAccessToken(existingToken);
}
OAuth2AccessToken obtainableAccessToken;
obtainableAccessToken = accessTokenProvider.obtainAccessToken(resource, tokenRequest);
if (obtainableAccessToken == null || obtainableAccessToken.getValue() == null) {
throw new IllegalStateException(
" Access token provider returned a null token, which is illegal according to the contract.");
}
oAuth2ClientContext.setAccessToken(obtainableAccessToken);
return obtainableAccessToken;
}
示例2: testAccessRootUrlWithOAuth2AccessToken
import org.springframework.security.oauth2.common.OAuth2AccessToken; //導入方法依賴的package包/類
@Test
public void testAccessRootUrlWithOAuth2AccessToken() throws Exception {
final ClientCredentialsResourceDetails resourceDetails = new ClientCredentialsResourceDetails();
resourceDetails.setClientId("myclient");
resourceDetails.setClientSecret("mysecret");
resourceDetails.setGrantType("client_credentials");
resourceDetails
.setAccessTokenUri("http://localhost:" + oAuth2ServerResource.getOauth2ServerPort() + "/oauth/token");
final OAuth2RestTemplate oAuth2RestTemplate = new OAuth2RestTemplate(resourceDetails);
final OAuth2AccessToken accessToken = oAuth2RestTemplate.getAccessToken();
final String accessTokenAsString = accessToken.getValue();
localSkipperResource.getMockMvc().perform(get("/api").header("Authorization", "bearer " + accessTokenAsString))
.andDo(print()).andExpect(status().isOk());
}
示例3: testAccessAboutUrlWithOAuth2AccessToken
import org.springframework.security.oauth2.common.OAuth2AccessToken; //導入方法依賴的package包/類
@Test
public void testAccessAboutUrlWithOAuth2AccessToken() throws Exception {
final ClientCredentialsResourceDetails resourceDetails = new ClientCredentialsResourceDetails();
resourceDetails.setClientId("myclient");
resourceDetails.setClientSecret("mysecret");
resourceDetails.setGrantType("client_credentials");
resourceDetails
.setAccessTokenUri("http://localhost:" + oAuth2ServerResource.getOauth2ServerPort() + "/oauth/token");
final OAuth2RestTemplate oAuth2RestTemplate = new OAuth2RestTemplate(resourceDetails);
final OAuth2AccessToken accessToken = oAuth2RestTemplate.getAccessToken();
final String accessTokenAsString = accessToken.getValue();
localSkipperResource.getMockMvc()
.perform(get("/api/about").header("Authorization", "bearer " + accessTokenAsString)).andDo(print())
.andExpect(status().isOk())
.andExpect(jsonPath("$.versionInfo.server.name", is("Spring Cloud Skipper Server")))
.andExpect(jsonPath("$.versionInfo.server.version", notNullValue()));
}
示例4: getUserInfo
import org.springframework.security.oauth2.common.OAuth2AccessToken; //導入方法依賴的package包/類
@SuppressWarnings("restriction")
private Map<String, Object> getUserInfo(String user) {
// String userJson = getRestTemplate().getForObject(getUrl("/v2/users/{guid}"), String.class, user);
// Map<String, Object> userInfo = (Map<String, Object>) JsonUtil.convertJsonToMap(userJson);
// return userInfo();
// TODO: remove this temporary hack once the /v2/users/ uri can be accessed by mere mortals
String userJson = "{}";
OAuth2AccessToken accessToken = oauthClient.getToken();
if (accessToken != null) {
String tokenString = accessToken.getValue();
int x = tokenString.indexOf('.');
int y = tokenString.indexOf('.', x + 1);
String encodedString = tokenString.substring(x + 1, y);
try {
byte[] decodedBytes = new sun.misc.BASE64Decoder().decodeBuffer(encodedString);
userJson = new String(decodedBytes, 0, decodedBytes.length, "UTF-8");
} catch (IOException e) {
}
}
return (JsonUtil.convertJsonToMap(userJson));
}
示例5: createToken
import org.springframework.security.oauth2.common.OAuth2AccessToken; //導入方法依賴的package包/類
private String createToken(Authentication userAuth) {
OAuth2Request storedOAuth2Request = new OAuth2Request(null, "web_app", null, true, Sets.newHashSet("openid"),
null, null, null, null);
OAuth2Authentication oauth2 = new OAuth2Authentication(storedOAuth2Request, userAuth);
OAuth2AccessToken oauthToken = tokenServices.createAccessToken(oauth2);
return oauthToken.getValue();
}
示例6: getAuthorizationHeader
import org.springframework.security.oauth2.common.OAuth2AccessToken; //導入方法依賴的package包/類
public String getAuthorizationHeader() {
OAuth2AccessToken accessToken = getToken();
if (accessToken != null) {
return accessToken.getTokenType() + " " + accessToken.getValue();
}
return null;
}
示例7: AuthenticationAccessToken
import org.springframework.security.oauth2.common.OAuth2AccessToken; //導入方法依賴的package包/類
/**
* Create a new OAuth2 Access Token holder.
*
* @param accessToken The Access Token.
* @param authentication The authentication.
* @param authenticationId The id of the authentication.
*/
public AuthenticationAccessToken(final OAuth2AccessToken accessToken,
final OAuth2Authentication authentication,
final String authenticationId) {
this.tokenId = accessToken.getValue();
this.accessToken = accessToken;
this.authenticationId = authenticationId;
this.userName = authentication.getName();
this.clientId = authentication.getOAuth2Request().getClientId();
this.authentication = authentication;
this.refreshToken = accessToken.getRefreshToken().getValue();
}
示例8: saveAccessToken
import org.springframework.security.oauth2.common.OAuth2AccessToken; //導入方法依賴的package包/類
@Override
public void saveAccessToken(OAuth2ProtectedResourceDetails resource,
Authentication authentication, OAuth2AccessToken accessToken) {
ClientUser clientUser = getClientUser(authentication);
clientUser.accessToken = accessToken.getValue();
clientUser.expirationTime = accessToken.getExpiration().getTime();
clientUser.additionalInformation = accessToken.getAdditionalInformation();
users.put(clientUser.username, clientUser);
}
示例9: acquireAccessToken
import org.springframework.security.oauth2.common.OAuth2AccessToken; //導入方法依賴的package包/類
protected OAuth2AccessToken acquireAccessToken(OAuth2ClientContext oauth2Context) throws UserRedirectRequiredException {
AccessTokenRequest accessTokenRequest = oauth2Context.getAccessTokenRequest();
if (accessTokenRequest != null) {
System.out.println("accesstokeRequest == " + accessTokenRequest.getCurrentUri());
}
if(accessTokenRequest == null) {
throw new AccessTokenRequiredException("No OAuth 2 security context has been established. Unable to access resource '" + this.resource.getId() + "'.", this.resource);
} else {
String stateKey = accessTokenRequest.getStateKey();
if(stateKey != null) {
System.out.println("stateKey == " + stateKey);
accessTokenRequest.setPreservedState(oauth2Context.removePreservedState(stateKey));
}
OAuth2AccessToken existingToken = oauth2Context.getAccessToken();
if(existingToken != null) {
accessTokenRequest.setExistingToken(existingToken);
}
OAuth2AccessToken accessToken = null;
accessToken = this.accessTokenProvider.obtainAccessToken(this.resource, accessTokenRequest);
if(accessToken != null && accessToken.getValue() != null) {
oauth2Context.setAccessToken(accessToken);
return accessToken;
} else {
throw new IllegalStateException("Access token provider returned a null access token, which is illegal according to the contract.");
}
}
}
示例10: storeAccessToken
import org.springframework.security.oauth2.common.OAuth2AccessToken; //導入方法依賴的package包/類
@Override
public void storeAccessToken(OAuth2AccessToken token, OAuth2Authentication authentication) {
String tokenId = token.getValue();
final RefreshTokenEntity refreshToken;
String authenticationKey = authenticationKeyGenerator.extractKey(authentication);
if (token.getRefreshToken() != null) {
refreshToken = refreshTokenRepository.findOneByTokenId(token.getRefreshToken().getValue()).orElseGet(() -> refreshTokenRepository.save(RefreshTokenEntity.builder().tokenId(token.getRefreshToken().getValue()).token(token.getRefreshToken()).authentication(authentication).build()));
} else {
refreshToken = null;
}
accessTokenRepository.findOneByAuthenticationId(authenticationKey).ifPresent(accessTokenEntity -> {
if (!tokenId.equals(accessTokenEntity.getTokenId())) {
accessTokenRepository.delete(accessTokenEntity);
}
});
AccessTokenEntity entityToSave = accessTokenRepository.findOneByTokenId(tokenId).map(accessTokenEntity -> {
accessTokenEntity.setToken(token);
accessTokenEntity.setAuthenticationId(authenticationKey);
accessTokenEntity.setAuthentication(authentication);
accessTokenEntity.setUserName(authentication.isClientOnly() ? null : authentication.getName());
accessTokenEntity.setClientId(authentication.getOAuth2Request().getClientId());
accessTokenEntity.setRefreshToken(refreshToken);
return accessTokenEntity;
}).orElseGet(() -> AccessTokenEntity.builder().tokenId(tokenId).token(token).authenticationId(authenticationKey).authentication(authentication).userName(authentication.isClientOnly() ? null : authentication.getName()).clientId(authentication.getOAuth2Request().getClientId()).refreshToken(refreshToken).build());
accessTokenRepository.save(entityToSave);
}
示例11: prepareRemoveAccessTokenStatements
import org.springframework.security.oauth2.common.OAuth2AccessToken; //導入方法依賴的package包/類
private List<RegularStatement> prepareRemoveAccessTokenStatements(OAuth2AccessToken token) {
//String tokenId = token.getValue();
String tokenValue = token.getValue();
String jsonOAuth2AccessToken = OAuthUtil.serializeOAuth2AccessToken(token);
List<RegularStatement> statementList = new ArrayList<RegularStatement>();
// Delete from AccessToken table
RegularStatement accessTokenDelete = prepareDeleteByPrimaryKeyRegularStatement(AccessToken.class, tokenValue);
statementList.add(accessTokenDelete);
// Lookup Authentication table for further deleting from AuthenticationToAccessToken table
Authentication authentication = authenticationRepository.findOne(tokenValue);
if (authentication != null) {
ByteBuffer bufferedOAuth2Authentication = authentication.getoAuth2Authentication();
byte[] serializedOAuth2Authentication = new byte[bufferedOAuth2Authentication.remaining()];
bufferedOAuth2Authentication.get(serializedOAuth2Authentication);
OAuth2Authentication oAuth2Authentication = SerializationUtils.deserialize(serializedOAuth2Authentication);
String clientId = oAuth2Authentication.getOAuth2Request().getClientId();
// Delete from Authentication table
RegularStatement authenticationDelete = prepareDeleteByPrimaryKeyRegularStatement(Authentication.class, tokenValue);
statementList.add(authenticationDelete);
// Delete from AuthenticationToAccessToken table
RegularStatement authToAccessDelete = prepareDeleteByPrimaryKeyRegularStatement(AuthenticationToAccessToken.class, authenticationKeyGenerator.extractKey(oAuth2Authentication));
statementList.add(authToAccessDelete);
// Delete from UsernameToAccessToken table
Optional<UsernameToAccessToken> optionalUsernameToAccessToken = usernameToAccessTokenRepository.findByKeyAndOAuth2AccessToken(OAuthUtil.getApprovalKey(clientId, oAuth2Authentication.getName()), jsonOAuth2AccessToken);
optionalUsernameToAccessToken.ifPresent(usernameToAccessToken -> {
Delete usernameToAccessDelete = CassandraTemplate.createDeleteQuery(UsernameToAccessToken.TABLE, usernameToAccessToken, null, cassandraTemplate.getConverter());
statementList.add(usernameToAccessDelete);
});
// Delete from ClientIdToAccessToken table
Optional<ClientIdToAccessToken> optionalClientIdToAccessToken = clientIdToAccessTokenRepository.findByKeyAndOAuth2AccessToken(clientId, jsonOAuth2AccessToken);
optionalClientIdToAccessToken.ifPresent(clientIdToAccessToken -> {
Delete clientIdToAccessDelete = CassandraTemplate.createDeleteQuery(ClientIdToAccessToken.TABLE, clientIdToAccessToken, null, cassandraTemplate.getConverter());
statementList.add(clientIdToAccessDelete);
});
}
return statementList;
}