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


Java Claims.getSubject方法代碼示例

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


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

示例1: getAuthentication

import io.jsonwebtoken.Claims; //導入方法依賴的package包/類
public Authentication getAuthentication(String token) {
    Claims claims = Jwts.parser()
        .setSigningKey(secretKey)
        .parseClaimsJws(token)
        .getBody();

    Collection<? extends GrantedAuthority> authorities = Arrays.stream(claims.get(AUTHORITIES_KEY)
        .toString()
        .split(","))
        .map(SimpleGrantedAuthority::new)
        .collect(Collectors.toList());

    User principal = new User(claims.getSubject(), "", authorities);

    return new UsernamePasswordAuthenticationToken(principal, token, authorities);
}
 
開發者ID:megadotnet,項目名稱:SpringBootDemoApp,代碼行數:17,代碼來源:TokenProvider.java

示例2: parseRefreshToken

import io.jsonwebtoken.Claims; //導入方法依賴的package包/類
public SecurityUser parseRefreshToken(RawAccessJwtToken rawAccessToken) {
  Jws<Claims> jwsClaims = rawAccessToken.parseClaims(settings.getTokenSigningKey());
  Claims claims = jwsClaims.getBody();
  String subject = claims.getSubject();
  List<String> scopes = claims.get(SCOPES, List.class);
  if (scopes == null || scopes.isEmpty()) {
    throw new IllegalArgumentException("Refresh Token doesn't have any scopes");
  }
  if (!scopes.get(0).equals(Authority.REFRESH_TOKEN.name())) {
    throw new IllegalArgumentException("Invalid Refresh Token scope");
  }
  boolean isPublic = claims.get(IS_PUBLIC, Boolean.class);
  UserPrincipal principal = new UserPrincipal(isPublic ? UserPrincipal.Type.PUBLIC_ID : UserPrincipal.Type.USER_NAME,
      subject);
  SecurityUser securityUser = new SecurityUser(new UserId(UUID.fromString(claims.get(USER_ID, String.class))));
  securityUser.setUserPrincipal(principal);
  return securityUser;
}
 
開發者ID:osswangxining,項目名稱:iotplatform,代碼行數:19,代碼來源:JwtTokenFactory.java

示例3: getAuthentication

import io.jsonwebtoken.Claims; //導入方法依賴的package包/類
public Authentication getAuthentication(String token) {
    Claims claims = Jwts.parser()
        .setSigningKey(secretKey)
        .parseClaimsJws(token)
        .getBody();

    Collection<? extends GrantedAuthority> authorities =
        Arrays.asList(claims.get(AUTHORITIES_KEY).toString().split(",")).stream()
            .map(SimpleGrantedAuthority::new)
            .collect(Collectors.toList());

    User principal = new User(claims.getSubject(), "",
        authorities);

    return new UsernamePasswordAuthenticationToken(principal, "", authorities);
}
 
開發者ID:klask-io,項目名稱:klask-io,代碼行數:17,代碼來源:TokenProvider.java

示例4: getUserFromToken

import io.jsonwebtoken.Claims; //導入方法依賴的package包/類
public JWTUserDetails getUserFromToken(String token){
    JWTUserDetails user;
    try {
        final Claims claims=getClaimsFromToken(token);
       String userId = getUserIdFromToken(token);
        String username=claims.getSubject();
        List<GrantedAuthority> authorities =AuthorityUtils.commaSeparatedStringToAuthorityList((String) claims.get(CLAIM_KEY_AUTHORITIES));
       /* boolean account_enabled = (Boolean) claims.get(CLAIM_KEY_ACCOUNT_ENABLED);
        boolean account_non_locked = (Boolean) claims.get(CLAIM_KEY_ACCOUNT_NON_LOCKED);
        boolean account_non_expired = (Boolean) claims.get(CLAIM_KEY_ACCOUNT_NON_EXPIRED);*/

        user = new JWTUserDetails(userId, username, "password",  authorities);
    }catch (Exception e){
        logger.error("getUserFromToken error");
        user=null;
    }
    return user;
}
 
開發者ID:BENULL,項目名稱:LushX,代碼行數:19,代碼來源:JWTUtils.java

示例5: parseAccessJwtToken

import io.jsonwebtoken.Claims; //導入方法依賴的package包/類
public SecurityUser parseAccessJwtToken(RawAccessJwtToken rawAccessToken) {
  Jws<Claims> jwsClaims = rawAccessToken.parseClaims(settings.getTokenSigningKey());
  Claims claims = jwsClaims.getBody();
  String subject = claims.getSubject();
  List<String> scopes = claims.get(SCOPES, List.class);
  if (scopes == null || scopes.isEmpty()) {
    throw new IllegalArgumentException("JWT Token doesn't have any scopes");
  }

  SecurityUser securityUser = new SecurityUser(new UserId(UUID.fromString(claims.get(USER_ID, String.class))));
  securityUser.setEmail(subject);
  securityUser.setAuthority(Authority.parse(scopes.get(0)));
  securityUser.setFirstName(claims.get(FIRST_NAME, String.class));
  securityUser.setLastName(claims.get(LAST_NAME, String.class));
  securityUser.setEnabled(claims.get(ENABLED, Boolean.class));
  boolean isPublic = claims.get(IS_PUBLIC, Boolean.class);
  UserPrincipal principal = new UserPrincipal(isPublic ? UserPrincipal.Type.PUBLIC_ID : UserPrincipal.Type.USER_NAME,
      subject);
  securityUser.setUserPrincipal(principal);
  String tenantId = claims.get(TENANT_ID, String.class);
  if (tenantId != null) {
    securityUser.setTenantId(new TenantId(UUID.fromString(tenantId)));
  }
  String customerId = claims.get(CUSTOMER_ID, String.class);
  if (customerId != null) {
    securityUser.setCustomerId(new CustomerId(UUID.fromString(customerId)));
  }

  return securityUser;
}
 
開發者ID:osswangxining,項目名稱:iotplatform,代碼行數:31,代碼來源:JwtTokenFactory.java

示例6: getUsernameFromToken

import io.jsonwebtoken.Claims; //導入方法依賴的package包/類
/**
 * Obtém o username (email) contido no token JWT.
 * 
 * @param token
 * @return String
 */
public String getUsernameFromToken(String token) {
	String username;
	try {
		Claims claims = getClaimsFromToken(token);
		username = claims.getSubject();
	} catch (Exception e) {
		username = null;
	}
	return username;
}
 
開發者ID:m4rciosouza,項目名稱:ponto-inteligente-api,代碼行數:17,代碼來源:JwtTokenUtil.java

示例7: getUsernameFromToken

import io.jsonwebtoken.Claims; //導入方法依賴的package包/類
public String getUsernameFromToken(String token) {
    String username;
    try {
        final Claims claims = getClaimsFromToken(token);
        username = claims.getSubject();
    } catch (Exception e) {
        username = null;
    }
    return username;
}
 
開發者ID:rodrigues882013,項目名稱:springboot-rest-api-skeleton,代碼行數:11,代碼來源:JwtTokenUtil.java

示例8: getUsernameFromToken

import io.jsonwebtoken.Claims; //導入方法依賴的package包/類
/**
 * 根據token得到用戶名
 *
 * @param token
 * @return
 */
public String getUsernameFromToken ( String token ) {
	String username;
	try {
		final Claims claims = getClaimsFromToken( token );
		username = claims.getSubject();
	} catch ( Exception e ) {
		username = null;
	}
	return username;
}
 
開發者ID:yujunhao8831,項目名稱:spring-boot-start-current,代碼行數:17,代碼來源:JwtTokenUtil.java

示例9: getAuthentication

import io.jsonwebtoken.Claims; //導入方法依賴的package包/類
static Authentication getAuthentication(HttpServletRequest request) {
    // 從Header中拿到token
    String token = request.getHeader(HEADER_STRING);

    if (token != null) {
        try {
            // 解析 Token
            Claims claims = Jwts.parser()
                    // 驗簽
                    .setSigningKey(SECRET)
                    // 去掉 Bearer
                    .parseClaimsJws(token.replace(TOKEN_PREFIX, ""))
                    .getBody();

            // 拿用戶名
            String user = claims.getSubject();

            // 得到 權限(角色)
            List<GrantedAuthority> authorities = AuthorityUtils.commaSeparatedStringToAuthorityList((String) claims.get("authorities"));

            // 返回驗證令牌
            return user != null ?
                    new UsernamePasswordAuthenticationToken(user, null, authorities) :
                    null;
        } catch (Exception e) {
            return null;
        }
    }
    return null;
}
 
開發者ID:myliang,項目名稱:fish-admin,代碼行數:31,代碼來源:TokenAuthenticationService.java

示例10: getUsernameFromToken

import io.jsonwebtoken.Claims; //導入方法依賴的package包/類
public String getUsernameFromToken(String token) {
    String username;
    try {
        final Claims clamis=getClaimsFromToken(token);
        username=clamis.getSubject();
    }catch (Exception e){
        username=null;
    }
    return username;
}
 
開發者ID:BENULL,項目名稱:LushX,代碼行數:11,代碼來源:JWTUtils.java

示例11: isAdmin

import io.jsonwebtoken.Claims; //導入方法依賴的package包/類
/**
 * Checks if use is an admin
 * 
 * @param token the JWT given
 * @return true if admin exists, false otherwise
 */
public static boolean isAdmin(String token) {
	Claims claims = null;
	UserDaoImpl ud = new UserDaoImpl();
	User user = null;
	String cUsername = null;
	boolean verified = false;
	
	if(token == null) {
		return false;
	}
	
	try {
		claims = Jwts.parser()
				.setSigningKey(getSecret())
				.parseClaimsJws(token).getBody();
		
		cUsername = claims.getSubject();
		user = ud.getUserByUsername(cUsername);
		
		if(cUsername == null || user == null || user.getRoleFlag() != 2) {
			return false;
		}
		
		verified = true;
		
	}catch(SignatureException se) {
		se.printStackTrace();
	}
	
	return verified;
}
 
開發者ID:grantleymorrison,項目名稱:FlashBoard,代碼行數:38,代碼來源:TokenService.java

示例12: getAuthentication

import io.jsonwebtoken.Claims; //導入方法依賴的package包/類
public Authentication getAuthentication(String token) {
        Claims claims = Jwts.parser()
            .setSigningKey(secretKey)
            .parseClaimsJws(token)
            .getBody();

        Collection<? extends GrantedAuthority> authorities =
            Arrays.stream(claims.get(AUTHORITIES_KEY).toString().split(","))
                .map(SimpleGrantedAuthority::new)
                .collect(Collectors.toList());

        User principal = new User(claims.getSubject(), "", authorities);

        return new UsernamePasswordAuthenticationToken(principal, "", authorities);

//        Claims claims = Jwts.parser()
//                .setSigningKey(secretKey)
//                .parseClaimsJws(token)
//                .getBody();
//
//        String principal = claims.getSubject();
//
//        // CHANGES START HERE
//        String roles = claims.get(AUTHORITIES_KEY, Map.class).get("roles").toString();
//        if(roles != null && roles.length() > 0) {
//            roles = roles.substring(1, roles.length() - 1);
//        }
//
//        Collection<? extends GrantedAuthority> authorities =
//                Arrays.asList(roles.split(",")).stream()
//                        .map(authority -> new SimpleGrantedAuthority("ROLE_" + authority.toUpperCase()))
//                        .collect(Collectors.toList());
//
//        return new UsernamePasswordAuthenticationToken(principal, token, authorities);
    }
 
開發者ID:AppertaFoundation,項目名稱:Code4Health-Platform,代碼行數:36,代碼來源:TokenProvider.java

示例13: getUsernameFromToken

import io.jsonwebtoken.Claims; //導入方法依賴的package包/類
/**
 * 從token中獲取username信息
 * @param token token
 * @return
 */
public String getUsernameFromToken(String token) {
    String username;
    try {
        final Claims claims = this.getClaimsFromToken(token);
        username = claims.getSubject();
    } catch (Exception e) {
        username = null;
    }
    return username;
}
 
開發者ID:YupaiTS,項目名稱:docs-manage,代碼行數:16,代碼來源:JwtHelper.java

示例14: decodeCookie

import io.jsonwebtoken.Claims; //導入方法依賴的package包/類
@Override
protected String[] decodeCookie(String cookieValue) throws InvalidCookieException {
  try {
    Claims claims = Jwts.parser()
        .setSigningKey(getKey())
        .parseClaimsJws(cookieValue)
        .getBody();

    return new String[] { claims.getId(), claims.getSubject() };
  } catch (JwtException e) {
    LOGGER.warn(e.getMessage());
    throw new InvalidCookieException(e.getMessage());
  }
}
 
開發者ID:springuni,項目名稱:springuni-particles,代碼行數:15,代碼來源:PersistentJwtTokenBasedRememberMeServices.java


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