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


Java Principal.getName方法代碼示例

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


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

示例1: checkAccess

import java.security.Principal; //導入方法依賴的package包/類
public Set<Integer> checkAccess(SecurityContext securityContext) {
    logger.debug("Performing agency incident data security check ...");
    Principal principal = securityContext.getUserPrincipal();
    String username = null;
    if (principal != null) {
        username = principal.getName();
    }
    if (StringUtils.isEmpty(username)) {
        logger.warn(
                "Access to agency incident data forbidden for user: Anonymous");
        throw new ArcGISSecurityException(403, "Forbidden", null);
    }
    Set<Integer> agencyIds = getAgencyIds(username);
    if (agencyIds == null || agencyIds.size() == 0) {
        logger.warn("Access to agency incident data ID forbidden for user: {}",
                username);
        throw new ArcGISSecurityException(403, "Forbidden", null);
    }
    logger.debug("Finished agency incident security check. "
                    + "User '{}' is permitted access to agency incident data for agencies [{}].",
            username, Arrays.toString(agencyIds.toArray(new Integer[agencyIds.size()])));
    return agencyIds;
}
 
開發者ID:Esri,項目名稱:server-extension-java,代碼行數:24,代碼來源:AgencyIncidentDataAccessController.java

示例2: getServiceHostName

import java.security.Principal; //導入方法依賴的package包/類
@Override
public String getServiceHostName(Principal principal) {
    if (principal == null) {
        return null;
    }
    String hostName = null;
    try {
        PrincipalName princName =
                new PrincipalName(principal.getName(),
                        PrincipalName.KRB_NT_SRV_HST);
        String[] nameParts = princName.getNameStrings();
        if (nameParts.length >= 2) {
            hostName = nameParts[1];
        }
    } catch (Exception e) {
        // ignore
    }
    return hostName;
}
 
開發者ID:AdoptOpenJDK,項目名稱:openjdk-jdk10,代碼行數:20,代碼來源:Krb5KeyExchangeService.java

示例3: getArtistRate

import java.security.Principal; //導入方法依賴的package包/類
/**
 * Returns User's rate for the specified Artist.
 *
 * @param user     user's principal.
 * @param artistId artists's identifier.
 * @return User's rate for the specified Artist. Empty rate will be returned in case when there is no such rate.
 */
public RateDto getArtistRate(Principal user, String artistId) {

    if (user == null || user.getName() == null || user.getName().isEmpty()) {
        return new RateDto();
    }

    String userId = user.getName();
    if (!userDao.exists(userId)) {
        throw new ResourceNotFoundException("User with id '" + userId + "' not found");
    }

    if (!artistDao.exists(artistId)) {
        throw new ResourceNotFoundException("Artist with id '" + artistId + "' not found");
    }

    ArtistRate rate = artistRateDao.getRate(userId, artistId);
    return (rate != null) ? artistRateToDto(rate) : new RateDto();
}
 
開發者ID:mapr-demos,項目名稱:mapr-music,代碼行數:26,代碼來源:RateService.java

示例4: printWelcome

import java.security.Principal; //導入方法依賴的package包/類
@RequestMapping(value="/welcome", method = RequestMethod.GET)
public String printWelcome(ModelMap model, Principal principal ) {
	
	System.out.println("***********LoginController printWelcome() Called***********");

	String name = principal.getName();
	model.addAttribute("username", name);
	model.addAttribute("message", "Spring Security authorisation example");
	return "hello";

}
 
開發者ID:Illusionist80,項目名稱:SpringTutorial,代碼行數:12,代碼來源:LoginController.java

示例5: doGet

import java.security.Principal; //導入方法依賴的package包/類
public void doGet(final HttpServletRequest httpServletRequest, final HttpServletResponse httpServletResponse) throws ServletException, IOException {
  final SecurityManager sm = SecurityManager.getInstance();
  final Principal userPrincipal = httpServletRequest.getUserPrincipal();
  final String name = userPrincipal.getName();
  final User userByName = sm.getUserByName(name);
  if (!userByName.isAdmin()) httpServletResponse.sendError(401);
  super.doGet(httpServletRequest, httpServletResponse);
}
 
開發者ID:parabuild-ci,項目名稱:parabuild-ci,代碼行數:9,代碼來源:ParabuildWebServiceServlet.java

示例6: doWebSocketConnect

import java.security.Principal; //導入方法依賴的package包/類
@Override
public WebSocket doWebSocketConnect(HttpServletRequest request, String protocol) {
    if (isStopped) {
        return null;
    }

    // FIXME: Replace this with globally shared opaque token to allow secure failover
    Principal p = request.getUserPrincipal();
    String userName = p != null ? p.getName() : FAKE_USERNAME;

    UiWebSocket socket = new UiWebSocket(directory, userName);
    synchronized (sockets) {
        sockets.add(socket);
    }
    return socket;
}
 
開發者ID:shlee89,項目名稱:athena,代碼行數:17,代碼來源:UiWebSocketServlet.java

示例7: init

import java.security.Principal; //導入方法依賴的package包/類
/**
 * Initialize the {@code XmlAuthorization} callback for a client having the given principal.
 * 
 * This method caches the full XML authorization file the first time it is invoked and caches all
 * the permissions for the provided {@code principal} to speed up lookup the
 * {@code authorizeOperation} calls. The permissions for the principal are maintained as a
 * {@link Map} of region name to the {@link HashSet} of operations allowed for that region. A
 * global entry with region name as empty string is also made for permissions provided for all the
 * regions.
 * 
 * @param principal the principal associated with the authenticated client
 * @param cache reference to the cache object
 * @param remoteMember the {@link DistributedMember} object for the remote authenticated client
 * 
 * @throws NotAuthorizedException if some exception condition happens during the initialization
 *         while reading the XML; in such a case all subsequent client operations will throw
 *         {@code NotAuthorizedException}
 */
@Override
public void init(final Principal principal, final DistributedMember remoteMember,
    final Cache cache) throws NotAuthorizedException {
  synchronized (sync) {
    XmlAuthorization.init(cache);
  }

  this.systemLogWriter = cache.getLogger();
  this.securityLogWriter = cache.getSecurityLogger();

  String name;
  if (principal != null) {
    name = principal.getName();
  } else {
    name = EMPTY_VALUE;
  }

  HashSet<String> roles = XmlAuthorization.userRoles.get(name);
  if (roles != null) {
    for (String roleName : roles) {
      Map<String, Map<OperationCode, FunctionSecurityPrmsHolder>> regionOperationMap =
          XmlAuthorization.rolePermissions.get(roleName);
      if (regionOperationMap != null) {
        for (Map.Entry<String, Map<OperationCode, FunctionSecurityPrmsHolder>> regionEntry : regionOperationMap
            .entrySet()) {
          String regionName = regionEntry.getKey();
          Map<OperationCode, FunctionSecurityPrmsHolder> regionOperations =
              this.allowedOps.get(regionName);
          if (regionOperations == null) {
            regionOperations = new HashMap<OperationCode, FunctionSecurityPrmsHolder>();
            this.allowedOps.put(regionName, regionOperations);
          }
          regionOperations.putAll(regionEntry.getValue());
        }
      }
    }
  }
}
 
開發者ID:ampool,項目名稱:monarch,代碼行數:57,代碼來源:XmlAuthorization.java

示例8: getRecommendationForUser

import java.security.Principal; //導入方法依賴的package包/類
private Recommendation getRecommendationForUser(Principal user) {

        // There is can be such situation when user has no rates and thus has no recommendation
        String userId = (user == null) ? ANONYMOUS_USER_ID : user.getName();
        Recommendation userRecommendation = recommendationDao.getById(userId);

        return (userRecommendation != null) ? userRecommendation : recommendationDao.getById(ANONYMOUS_USER_ID);
    }
 
開發者ID:mapr-demos,項目名稱:mapr-music,代碼行數:9,代碼來源:RecommendationService.java

示例9: equals

import java.security.Principal; //導入方法依賴的package包/類
@Override
public boolean equals(Object o) {
    if ( this == o ) {
        return true;
    }
    if ( o == null || !( o instanceof Principal ) ) {
        return false;
    }
    Principal p = (Principal) o;
    return name == null ? p.getName() == null : name.contentEquals( p.getName() );
}
 
開發者ID:agroal,項目名稱:agroal,代碼行數:12,代碼來源:NamePrincipal.java

示例10: admin

import java.security.Principal; //導入方法依賴的package包/類
@GetMapping("/admin")
String admin(Principal principal) {
    String applicationId = principal.getName();
    String certificateSerialNumber = this.serialNumberExtractor.getSerialNumber(principal);

    this.logger.info("Received request for /admin with certificate for {} with SN {}", applicationId, certificateSerialNumber);
    return String.format("You authenticated using x509 certificate for %s with SN %s", applicationId, certificateSerialNumber);
}
 
開發者ID:nebhale,項目名稱:mtls-sample,代碼行數:9,代碼來源:ServerApplication.java

示例11: printWelcome

import java.security.Principal; //導入方法依賴的package包/類
@RequestMapping(value="/welcome", method = RequestMethod.GET)
public String printWelcome(ModelMap model, Principal principal ) {
	
	System.out.println("***********LoginController Called***********");

	String name = principal.getName();
	model.addAttribute("username", name);
	model.addAttribute("message", "Spring Security Custom Form example");
	return "hello";

}
 
開發者ID:Illusionist80,項目名稱:SpringTutorial,代碼行數:12,代碼來源:LoginController.java

示例12: doesNameMatchPattern

import java.security.Principal; //導入方法依賴的package包/類
/**
 * Does principal name match pattern?
 *
 * @param principal the principal
 * @param pattern   the pattern
 * @return true, if successful
 */
private static boolean doesNameMatchPattern(final Principal principal, final Pattern pattern) {
    if (pattern != null) {
        final String name = principal.getName();
        final boolean result = pattern.matcher(name).matches();
        LOGGER.debug("[{}] matches [{}] == [{}]", pattern.pattern(), name, result);
        return result;
    }
    return true;
}
 
開發者ID:mrluo735,項目名稱:cas-5.1.0,代碼行數:17,代碼來源:X509CredentialsAuthenticationHandler.java

示例13: delegatedContext

import java.security.Principal; //導入方法依賴的package包/類
public AccessControlContext
    delegatedContext(AccessControlContext authenticatedACC,
                     Subject delegatedSubject,
                     boolean removeCallerContext)
        throws SecurityException {

    if (System.getSecurityManager() != null && authenticatedACC == null) {
        throw new SecurityException("Illegal AccessControlContext: null");
    }

    // Check if the subject delegation permission allows the
    // authenticated subject to assume the identity of each
    // principal in the delegated subject
    //
    Collection<Principal> ps = getSubjectPrincipals(delegatedSubject);
    final Collection<Permission> permissions = new ArrayList<>(ps.size());
    for(Principal p : ps) {
        final String pname = p.getClass().getName() + "." + p.getName();
        permissions.add(new SubjectDelegationPermission(pname));
    }
    PrivilegedAction<Void> action =
        new PrivilegedAction<Void>() {
            public Void run() {
                for (Permission sdp : permissions) {
                    AccessController.checkPermission(sdp);
                }
                return null;
            }
        };
    AccessController.doPrivileged(action, authenticatedACC);

    return getDelegatedAcc(delegatedSubject, removeCallerContext);
}
 
開發者ID:lambdalab-mirror,項目名稱:jdk8u-jdk,代碼行數:34,代碼來源:SubjectDelegator.java

示例14: getValidCredentials

import java.security.Principal; //導入方法依賴的package包/類
@Override
public Properties getValidCredentials(final Principal principal) {
  final String userName = principal.getName();

  if (DummyAuthenticator.checkValidName(userName)) {
    Properties props = new Properties();
    props.setProperty(UserPasswordAuthInit.USER_NAME, userName);
    props.setProperty(UserPasswordAuthInit.PASSWORD, userName);
    return props;

  } else {
    throw new IllegalArgumentException("Dummy: [" + userName + "] is not a valid user");
  }
}
 
開發者ID:ampool,項目名稱:monarch,代碼行數:15,代碼來源:DummyCredentialGenerator.java

示例15: fromPrincipal

import java.security.Principal; //導入方法依賴的package包/類
/**
 * Create a user information object
 *
 * @param principal
 * @return Returns the converted user information object or
 *         {@link #ANONYMOUS} if principal was <code>null</code>. Never
 *         returns <code>null</code>.
 */
public static UserInformation fromPrincipal ( final Principal principal )
{
    if ( principal == null )
    {
        return ANONYMOUS;
    }
    return new UserInformation ( principal.getName () );
}
 
開發者ID:eclipse,項目名稱:neoscada,代碼行數:17,代碼來源:UserInformation.java


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