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


Java KerberosTicket.getServer方法代碼示例

本文整理匯總了Java中javax.security.auth.kerberos.KerberosTicket.getServer方法的典型用法代碼示例。如果您正苦於以下問題:Java KerberosTicket.getServer方法的具體用法?Java KerberosTicket.getServer怎麽用?Java KerberosTicket.getServer使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在javax.security.auth.kerberos.KerberosTicket的用法示例。


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

示例1: init

import javax.security.auth.kerberos.KerberosTicket; //導入方法依賴的package包/類
/**
 * Creates an instance of KerberosClientKeyExchange consisting of the
 * Kerberos service ticket, authenticator and encrypted premaster secret.
 * Called by client handshaker.
 *
 * @param serverName name of server with which to do handshake;
 *             this is used to get the Kerberos service ticket
 * @param protocolVersion Maximum version supported by client (i.e,
 *          version it requested in client hello)
 * @param rand random number generator to use for generating pre-master
 *          secret
 */
@Override
public void init(String serverName,
    AccessControlContext acc, ProtocolVersion protocolVersion,
    SecureRandom rand) throws IOException {

     // Get service ticket
     KerberosTicket ticket = getServiceTicket(serverName, acc);
     encodedTicket = ticket.getEncoded();

     // Record the Kerberos principals
     peerPrincipal = ticket.getServer();
     localPrincipal = ticket.getClient();

     // Optional authenticator, encrypted using session key,
     // currently ignored

     // Generate premaster secret and encrypt it using session key
     EncryptionKey sessionKey = new EncryptionKey(
                                    ticket.getSessionKeyType(),
                                    ticket.getSessionKey().getEncoded());

     preMaster = new KerberosPreMasterSecret(protocolVersion,
         rand, sessionKey);
}
 
開發者ID:SunburstApps,項目名稱:OpenJSharp,代碼行數:37,代碼來源:KerberosClientKeyExchangeImpl.java

示例2: ExchangerImpl

import javax.security.auth.kerberos.KerberosTicket; //導入方法依賴的package包/類
ExchangerImpl(String serverName, AccessControlContext acc,
        ProtocolVersion protocolVersion, SecureRandom rand) throws IOException {

    // Get service ticket
    KerberosTicket ticket = getServiceTicket(serverName, acc);
    encodedTicket = ticket.getEncoded();

    // Record the Kerberos principals
    peerPrincipal = ticket.getServer();
    localPrincipal = ticket.getClient();

    // Optional authenticator, encrypted using session key,
    // currently ignored

    // Generate premaster secret and encrypt it using session key
    EncryptionKey sessionKey = new EncryptionKey(
            ticket.getSessionKeyType(),
            ticket.getSessionKey().getEncoded());

    preMaster = new KerberosPreMasterSecret(protocolVersion,
            rand, sessionKey);
}
 
開發者ID:AdoptOpenJDK,項目名稱:openjdk-jdk10,代碼行數:23,代碼來源:Krb5KeyExchangeService.java

示例3: getTGT

import javax.security.auth.kerberos.KerberosTicket; //導入方法依賴的package包/類
/**
 * Get the Kerberos TGT
 * @return the user's TGT or null if none was found
 */
private synchronized KerberosTicket getTGT() {
  Set<KerberosTicket> tickets = 
    subject.getPrivateCredentials(KerberosTicket.class);
  for(KerberosTicket ticket: tickets) {
    KerberosPrincipal server = ticket.getServer();
    if (server.getName().equals("krbtgt/" + server.getRealm() + 
                                "@" + server.getRealm())) {
      if (LOG.isDebugEnabled()) {
        LOG.debug("Found tgt " + ticket);
      }
      return ticket;
    }
  }
  return null;
}
 
開發者ID:apache,項目名稱:servicemix-bundles,代碼行數:20,代碼來源:UserGroupInformation.java

示例4: init

import javax.security.auth.kerberos.KerberosTicket; //導入方法依賴的package包/類
/**
 * Creates an instance of KerberosClientKeyExchange consisting of the
 * Kerberos service ticket, authenticator and encrypted premaster secret.
 * Called by client handshaker.
 *
 * @param serverName name of server with which to do handshake;
 *             this is used to get the Kerberos service ticket
 * @param protocolVersion Maximum version supported by client (i.e,
 *          version it requested in client hello)
 * @param rand random number generator to use for generating pre-master
 *          secret
 */
@Override
public void init(String serverName, boolean isLoopback,
    AccessControlContext acc, ProtocolVersion protocolVersion,
    SecureRandom rand) throws IOException {

     // Get service ticket
     KerberosTicket ticket = getServiceTicket(serverName, isLoopback, acc);
     encodedTicket = ticket.getEncoded();

     // Record the Kerberos principals
     peerPrincipal = ticket.getServer();
     localPrincipal = ticket.getClient();

     // Optional authenticator, encrypted using session key,
     // currently ignored

     // Generate premaster secret and encrypt it using session key
     EncryptionKey sessionKey = new EncryptionKey(
                                    ticket.getSessionKeyType(),
                                    ticket.getSessionKey().getEncoded());

     preMaster = new KerberosPreMasterSecret(protocolVersion,
         rand, sessionKey);
}
 
開發者ID:openjdk,項目名稱:jdk7-jdk,代碼行數:37,代碼來源:KerberosClientKeyExchangeImpl.java

示例5: getTGT

import javax.security.auth.kerberos.KerberosTicket; //導入方法依賴的package包/類
private synchronized KerberosTicket getTGT() {
    Set<KerberosTicket> tickets = subject.getPrivateCredentials(KerberosTicket.class);
    for(KerberosTicket ticket: tickets) {
        KerberosPrincipal server = ticket.getServer();
        if (server.getName().equals("krbtgt/" + server.getRealm() + "@" + server.getRealm())) {
            LOG.debug("Client principal is \"" + ticket.getClient().getName() + "\".");
            LOG.debug("Server principal is \"" + ticket.getServer().getName() + "\".");
            return ticket;
        }
    }
    return null;
}
 
開發者ID:maoling,項目名稱:fuck_zookeeper,代碼行數:13,代碼來源:Login.java

示例6: getTGT

import javax.security.auth.kerberos.KerberosTicket; //導入方法依賴的package包/類
private synchronized KerberosTicket getTGT() {
    Set<KerberosTicket> tickets = subject.getPrivateCredentials(KerberosTicket.class);
    for (KerberosTicket ticket : tickets) {
        KerberosPrincipal server = ticket.getServer();
        if (server.getName().equals("krbtgt/" + server.getRealm() + "@" + server.getRealm())) {
            log.debug("Found TGT with client principal '{}' and server principal '{}'.", ticket.getClient().getName(),
                    ticket.getServer().getName());
            return ticket;
        }
    }
    return null;
}
 
開發者ID:YMCoding,項目名稱:kafka-0.11.0.0-src-with-comment,代碼行數:13,代碼來源:KerberosLogin.java

示例7: getInstance

import javax.security.auth.kerberos.KerberosTicket; //導入方法依賴的package包/類
static Krb5InitCredential getInstance(GSSCaller caller, Krb5NameElement name,
                               int initLifetime)
    throws GSSException {

    KerberosTicket tgt = getTgt(caller, name, initLifetime);
    if (tgt == null)
        throw new GSSException(GSSException.NO_CRED, -1,
                               "Failed to find any Kerberos tgt");

    if (name == null) {
        String fullName = tgt.getClient().getName();
        name = Krb5NameElement.getInstance(fullName,
                                   Krb5MechFactory.NT_GSS_KRB5_PRINCIPAL);
    }

    return new Krb5InitCredential(name,
                                  tgt.getEncoded(),
                                  tgt.getClient(),
                                  tgt.getServer(),
                                  tgt.getSessionKey().getEncoded(),
                                  tgt.getSessionKeyType(),
                                  tgt.getFlags(),
                                  tgt.getAuthTime(),
                                  tgt.getStartTime(),
                                  tgt.getEndTime(),
                                  tgt.getRenewTill(),
                                  tgt.getClientAddresses());
}
 
開發者ID:AdoptOpenJDK,項目名稱:openjdk-jdk10,代碼行數:29,代碼來源:Krb5InitCredential.java

示例8: getTGT

import javax.security.auth.kerberos.KerberosTicket; //導入方法依賴的package包/類
private synchronized KerberosTicket getTGT() {
    Set<KerberosTicket> tickets = subject.getPrivateCredentials(KerberosTicket.class);
    for (KerberosTicket ticket : tickets) {
        KerberosPrincipal server = ticket.getServer();
        if (server.getName().equals("krbtgt/" + server.getRealm() + "@" + server.getRealm())) {
            log.debug("Found TGT {}.", ticket);
            return ticket;
        }
    }
    return null;
}
 
開發者ID:txazo,項目名稱:kafka,代碼行數:12,代碼來源:KerberosLogin.java

示例9: getTGT

import javax.security.auth.kerberos.KerberosTicket; //導入方法依賴的package包/類
private synchronized KerberosTicket getTGT() {
    Set<KerberosTicket> tickets = subject.getPrivateCredentials(KerberosTicket.class);
    for(KerberosTicket ticket: tickets) {
        KerberosPrincipal server = ticket.getServer();
        if (server.getName().equals("krbtgt/" + server.getRealm() + "@" + server.getRealm())) {
            LOG.debug("Found tgt " + ticket + ".");
            return ticket;
        }
    }
    return null;
}
 
開發者ID:gerritjvv,項目名稱:bigstreams,代碼行數:12,代碼來源:Login.java

示例10: getTGT

import javax.security.auth.kerberos.KerberosTicket; //導入方法依賴的package包/類
private KerberosTicket getTGT() {
    Set<KerberosTicket> tickets = loginContext.getSubject().getPrivateCredentials(KerberosTicket.class);
    for (KerberosTicket ticket : tickets) {
        KerberosPrincipal server = ticket.getServer();
        if (server.getName().equals("krbtgt/" + server.getRealm() + "@" + server.getRealm())) {
            log.debug("Found TGT with client principal '{}' and server principal '{}'.", ticket.getClient().getName(),
                    ticket.getServer().getName());
            return ticket;
        }
    }
    return null;
}
 
開發者ID:hortonworks,項目名稱:registry,代碼行數:13,代碼來源:KerberosLogin.java

示例11: isTargetPrincipal

import javax.security.auth.kerberos.KerberosTicket; //導入方法依賴的package包/類
boolean isTargetPrincipal(KerberosTicket ticket, String remoteSvcPrincipal) {
    if (ticket == null) {
        return false;
    }

    KerberosPrincipal principal = ticket.getServer();
    if (LOG.isDebugEnabled()) {
        LOG.debug("KerberosAuthority:isTargetPrincipal: our princ=" + servicePrincipal + " ticket princ=" + principal.getName());
    }

    if (principal.getName().equals(remoteSvcPrincipal)) {
        return true;
    }
    return false;
}
 
開發者ID:yahoo,項目名稱:athenz,代碼行數:16,代碼來源:KerberosAuthority.java

示例12: getTGT

import javax.security.auth.kerberos.KerberosTicket; //導入方法依賴的package包/類
private static KerberosTicket getTGT(Subject subject) {
    Set<KerberosTicket> tickets = subject.getPrivateCredentials(KerberosTicket.class);
    for (KerberosTicket ticket : tickets) {
        KerberosPrincipal server = ticket.getServer();
        if (server.getName().equals("krbtgt/" + server.getRealm() + "@" + server.getRealm())) {
            tickets = null;
            return ticket;
        }
    }
    tickets = null;
    return null;
}
 
開發者ID:kkllwww007,項目名稱:jstrom,代碼行數:13,代碼來源:AutoTGT.java

示例13: getTGT

import javax.security.auth.kerberos.KerberosTicket; //導入方法依賴的package包/類
private synchronized KerberosTicket getTGT() {
  Set<KerberosTicket> tickets = subject.getPrivateCredentials(KerberosTicket.class);
  for (KerberosTicket ticket : tickets) {
    KerberosPrincipal server = ticket.getServer();
    if (server.getName().equals("krbtgt/" + server.getRealm() + "@" + server.getRealm())) {
      log.debug("Found TGT with client principal '{}' and server principal '{}'.", ticket.getClient().getName(),
          ticket.getServer().getName());
      return ticket;
    }
  }
  return null;
}
 
開發者ID:streamsets,項目名稱:datacollector,代碼行數:13,代碼來源:KerberosLogin.java

示例14: getKerberosTicket

import javax.security.auth.kerberos.KerberosTicket; //導入方法依賴的package包/類
/**
 * Get the Kerberos TGT, it purges old expired tickets from Subject
 * @return the user's TGT or null if none was found
 */
@VisibleForTesting
synchronized KerberosTicket getKerberosTicket() {
  KerberosTicket found = null;
  Set<KerberosTicket> expiredTickets = new HashSet<>();
  SortedSet<KerberosTicket> tickets = new TreeSet<>(new Comparator<KerberosTicket>() {
    @Override
    public int compare(KerberosTicket ticket1, KerberosTicket ticket2) {
      return Long.compare(ticket1.getEndTime().getTime(), ticket2.getEndTime().getTime());
    }
  });
  for (KerberosTicket ticket : getSubject().getPrivateCredentials(KerberosTicket.class)) {
    KerberosPrincipal principal = ticket.getServer();
    String principalName = Utils.format("krbtgt/{}@{}", principal.getRealm(), principal.getRealm());
    if (principalName.equals(principal.getName())) {
      if (ticket.getEndTime().getTime() < getTimeNow()) {
        // the ticket in question expired, we should remove it from the subject as it is useless
        expiredTickets.add(ticket);
        LOG.debug("Found expired Kerberos ticket '{}', will remove it", ticket.getServer().getName());
      }
      tickets.add(ticket);
    }
  }
  if (!tickets.isEmpty()) {
    // lets get the most recent ticket
    found = tickets.last();
    // take out the last ticket from expired tickets as we don' want to purge it as we want to renew that one
    // this should not really happen as we renew before the expire
    if (expiredTickets.contains(found)) {
      LOG.warn("Last Kerberos ticket '{}' already expired", found.getServer().getName());
      found = null;
    }
  }
  if (!expiredTickets.isEmpty()) {
    // removing expired tickets from subject
    getSubject().getPrivateCredentials().removeAll(expiredTickets);
    LOG.debug("Removed '{}' expired Kerberos tickets from SDC subject", expiredTickets.size());
  }
  return found;
}
 
開發者ID:streamsets,項目名稱:datacollector,代碼行數:44,代碼來源:SecurityContext.java

示例15: initLoginContext

import javax.security.auth.kerberos.KerberosTicket; //導入方法依賴的package包/類
private synchronized void initLoginContext() {
    if (loggedIn) {
        return;
    }

    try {
        LoginCallbackHandler callback = new LoginCallbackHandler(config.getSsoJaasPrincipalPassword());
        loginContext = new LoginContext(config.getSsoJaasConfigName(), callback);
        loginContext.login();

        loggedIn = true;

        Subject serviceSubject = loginContext.getSubject();

        for (KerberosTicket ticket : serviceSubject.getPrivateCredentials(KerberosTicket.class)) {
            log.info("AuthTime: " + ticket.getAuthTime());
            log.info("StartTime: " + ticket.getStartTime());
            log.info("EndTime: " + ticket.getEndTime());
            log.info("RenewTill: " + ticket.getRenewTill());

            KerberosPrincipal client = ticket.getClient();
            log.info("Client: name=" + client.getName() + ", realm=" + client.getRealm());

            KerberosPrincipal server = ticket.getServer();
            log.info("Server: name=" + server.getName() + ", realm=" + server.getRealm());
        }

    } catch (LoginException ex) {
        log.error(ex.getMessage(), ex);
    }
}
 
開發者ID:imCodePartnerAB,項目名稱:imcms,代碼行數:32,代碼來源:KerberosLoginService.java


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