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


Java AuthorizeCallback.getAuthorizedID方法代碼示例

本文整理匯總了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);

}
 
開發者ID:shannah,項目名稱:cn1,代碼行數:26,代碼來源:AuthorizeCallbackTest.java

示例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;
}
 
開發者ID:igniterealtime,項目名稱:Openfire,代碼行數:77,代碼來源:SaslServerPlainImpl.java

示例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();
}
 
開發者ID:kontalk,項目名稱:tigase-server,代碼行數:54,代碼來源:AbstractSaslSCRAM.java

示例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;
}
 
開發者ID:kontalk,項目名稱:tigase-server,代碼行數:50,代碼來源:SaslPLAIN.java


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