本文整理匯總了Java中javax.security.sasl.AuthorizeCallback.getAuthorizedID方法的典型用法代碼示例。如果您正苦於以下問題:Java AuthorizeCallback.getAuthorizedID方法的具體用法?Java AuthorizeCallback.getAuthorizedID怎麽用?Java AuthorizeCallback.getAuthorizedID使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類javax.security.sasl.AuthorizeCallback
的用法示例。
在下文中一共展示了AuthorizeCallback.getAuthorizedID方法的4個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。
示例1: assertDeserialized
import javax.security.sasl.AuthorizeCallback; //導入方法依賴的package包/類
public void assertDeserialized(Serializable oref, Serializable otest) {
AuthorizeCallback ref = (AuthorizeCallback) oref;
AuthorizeCallback test = (AuthorizeCallback) otest;
String idC = ref.getAuthenticationID();
String idZ = ref.getAuthorizationID();
String id = ref.getAuthorizedID();
boolean is = ref.isAuthorized();
if (idC == null) {
assertNull(test.getAuthenticationID());
} else {
assertEquals(test.getAuthenticationID(), idC);
}
if (idZ == null) {
assertNull(test.getAuthorizationID());
} else {
assertEquals(test.getAuthorizationID(), idZ);
}
if (id == null) {
assertNull(test.getAuthorizedID());
} else {
assertEquals(test.getAuthorizedID(), id);
}
assertEquals(test.isAuthorized(), is);
}
示例2: evaluateResponse
import javax.security.sasl.AuthorizeCallback; //導入方法依賴的package包/類
/**
* Evaluates the response data and generates a challenge.
*
* If a response is received from the client during the authentication
* process, this method is called to prepare an appropriate next
* challenge to submit to the client. The challenge is null if the
* authentication has succeeded and no more challenge data is to be sent
* to the client. It is non-null if the authentication must be continued
* by sending a challenge to the client, or if the authentication has
* succeeded but challenge data needs to be processed by the client.
* <tt>isComplete()</tt> should be called
* after each call to <tt>evaluateResponse()</tt>,to determine if any further
* response is needed from the client.
*
* @param response The non-null (but possibly empty) response sent
* by the client.
*
* @return The possibly null challenge to send to the client.
* It is null if the authentication has succeeded and there is
* no more challenge data to be sent to the client.
* @exception SaslException If an error occurred while processing
* the response or generating a challenge.
*/
@Override
public byte[] evaluateResponse(byte[] response)
throws SaslException {
if (completed) {
throw new IllegalStateException("PLAIN authentication already completed");
}
if (aborted) {
throw new IllegalStateException("PLAIN authentication previously aborted due to error");
}
try {
if(response.length != 0) {
String data = new String(response, StandardCharsets.UTF_8);
StringTokenizer tokens = new StringTokenizer(data, "\0");
if (tokens.countTokens() > 2) {
username = tokens.nextToken();
principal = tokens.nextToken();
} else {
username = tokens.nextToken();
principal = username;
}
password = tokens.nextToken();
NameCallback ncb = new NameCallback("PLAIN authentication ID: ",principal);
VerifyPasswordCallback vpcb = new VerifyPasswordCallback(password.toCharArray());
cbh.handle(new Callback[]{ncb,vpcb});
if (vpcb.getVerified()) {
vpcb.clearPassword();
AuthorizeCallback acb = new AuthorizeCallback(principal,username);
cbh.handle(new Callback[]{acb});
if(acb.isAuthorized()) {
username = acb.getAuthorizedID();
completed = true;
} else {
completed = true;
username = null;
throw new SaslException("PLAIN: user not authorized: "+principal);
}
} else {
throw new SaslException("PLAIN: user not authorized: "+principal);
}
} else {
//Client gave no initial response
if( counter++ > 1 ) {
throw new SaslException("PLAIN expects a response");
}
return null;
}
} catch (UnsupportedCallbackException | IOException e) {
aborted = true;
throw new SaslException("PLAIN authentication failed for: "+username, e);
}
return null;
}
示例3: processClientLastMessage
import javax.security.sasl.AuthorizeCallback; //導入方法依賴的package包/類
protected byte[] processClientLastMessage(byte[] data) throws SaslException, InvalidKeyException, NoSuchAlgorithmException {
Matcher r = CLIENT_LAST_MESSAGE.matcher(new String(data, CHARSET));
if (!r.matches())
throw new SaslException("Bad challenge syntax");
final String clmWithoutProof = r.group("withoutProof");
final byte[] clmCb = Base64.decode(r.group("cb"));
final String clmNonce = r.group("nonce");
final String clmProof = r.group("proof");
byte[] calculatedCb = calculateC();
if (!(new String(clmCb, CHARSET)).startsWith(cfmGs2header)) {
throw new XmppSaslException(SaslError.not_authorized, "Invalid GS2 header");
} else if (!Arrays.equals(clmCb, calculatedCb)) {
if (log.isLoggable(Level.FINEST))
log.log(Level.FINEST, "Channel bindings does not match. expected: {0}; received: {1}",
new Object[]{calculatedCb, clmCb});
throw new XmppSaslException(SaslError.not_authorized, "Channel bindings does not match");
}
if (!clmNonce.equals(sfmNonce)) {
throw new XmppSaslException(SaslError.not_authorized, "Wrong nonce");
}
final String authMessage = cfmBareMessage + "," + sfmMessage + "," + clmWithoutProof;
byte[] clientSignature = hmac(key(storedKey), authMessage.getBytes());
byte[] clientProof = xor(clientKey, clientSignature);
byte[] dcp = Base64.decode(clmProof);
boolean proofMatch = Arrays.equals(clientProof, dcp);
if (proofMatch == false) {
throw new XmppSaslException(SaslError.not_authorized, "Password not verified");
}
final AuthorizeCallback ac = new AuthorizeCallback(cfmUsername, cfmAuthzid);
handleCallbacks(ac);
if (ac.isAuthorized() == true) {
authorizedId = ac.getAuthorizedID();
} else {
throw new XmppSaslException(SaslError.invalid_authzid, "SCRAM: " + cfmAuthzid + " is not authorized to act as "
+ cfmAuthzid);
}
byte[] serverKey = hmac(key(saltedPassword), serverKeyData);
byte[] serverSignature = hmac(key(serverKey), authMessage.getBytes());
final StringBuilder serverStringMessage = new StringBuilder();
serverStringMessage.append("v=").append(Base64.encode(serverSignature));
step = Step.finished;
complete = true;
return serverStringMessage.toString().getBytes();
}
示例4: evaluateResponse
import javax.security.sasl.AuthorizeCallback; //導入方法依賴的package包/類
@Override
public byte[] evaluateResponse(byte[] response) throws SaslException {
String[] data = split(response, "");
if (data.length != 3)
throw new XmppSaslException(SaslError.malformed_request, "Invalid number of message parts");
final String authzid = data[0];
final String authcid = data[1];
final String passwd = data[2];
if (authcid.length() < 1)
throw new XmppSaslException(SaslError.malformed_request, "Authentication identity string is empty");
if (authcid.length() > 255)
throw new XmppSaslException(SaslError.malformed_request, "Authentication identity string is too long");
if (!isEmpty(authzid) && authzid.length() > 255)
throw new XmppSaslException(SaslError.malformed_request, "Authorization identity string is too long");
if (passwd.length() > 255)
throw new XmppSaslException(SaslError.malformed_request, "Password string is too long");
final NameCallback nc = new NameCallback("Authentication identity", authcid);
final VerifyPasswordCallback vpc = new VerifyPasswordCallback(passwd);
handleCallbacks(nc, vpc);
if (vpc.isVerified() == false) {
throw new XmppSaslException(SaslError.not_authorized, "Password not verified");
}
final String authorizationJID = isEmpty(authzid) ? nc.getName() : authzid;
final AuthorizeCallback ac = new AuthorizeCallback(nc.getName(), authorizationJID);
handleCallbacks(ac);
if (ac.isAuthorized() == true) {
authorizedId = ac.getAuthorizedID();
} else {
throw new XmppSaslException(SaslError.invalid_authzid, "PLAIN: " + authcid + " is not authorized to act as "
+ authorizationJID);
}
complete = true;
return null;
}