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


Java SecurityUtils類代碼示例

本文整理匯總了Java中org.apache.shiro.SecurityUtils的典型用法代碼示例。如果您正苦於以下問題:Java SecurityUtils類的具體用法?Java SecurityUtils怎麽用?Java SecurityUtils使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。


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

示例1: getRealm

import org.apache.shiro.SecurityUtils; //導入依賴的package包/類
@SuppressWarnings("unchecked")
public static <T> T getRealm(Class<? extends Realm> realmType){
	RealmSecurityManager securityManager = (RealmSecurityManager) SecurityUtils.getSecurityManager();
	if(!CollectionUtils.isEmpty(securityManager.getRealms())){
		for(Iterator<Realm> it = securityManager.getRealms().iterator(); it.hasNext();){
			Realm realm = it.next();
			if(realm.getClass().equals(realmType)){
				return (T) realm;
			}
		}
	}
	return null;
}
 
開發者ID:penggle,項目名稱:xproject,代碼行數:14,代碼來源:ShiroUtils.java

示例2: afterReturn

import org.apache.shiro.SecurityUtils; //導入依賴的package包/類
/**
 * @param joinPoint
 */
@AfterReturning("logAnnoAspect()")

public void afterReturn(JoinPoint joinPoint) {
    MethodSignature methodSignature = (MethodSignature) joinPoint.getSignature();
    Method method = methodSignature.getMethod();
    LogModify logModifyAnno = method.getAnnotation(LogModify.class);
    if (null != logModifyAnno) {

        BaseEntity entity = (BaseEntity) joinPoint.getArgs()[0];
        Log log = new Log();
        log.setUserId(((User) SecurityUtils.getSubject().getSession().getAttribute("curUser")).getId());
        log.setAction(ACTION + logModifyAnno.resource());
        log.setResource(entity.getLogResource());
        log.setResourceId(entity.getId());
        logService.insert(log);
    }
}
 
開發者ID:melonlee,項目名稱:PowerApi,代碼行數:21,代碼來源:LogModifyAdvice.java

示例3: articleVote

import org.apache.shiro.SecurityUtils; //導入依賴的package包/類
/**
 * 用戶對文章進行點讚
 *
 * @param articleId 文章id
 * @return
 */
@ResponseBody
@RequestMapping(method = RequestMethod.POST)
public ResponseEntity articleVote(int articleId) {
    MMSnsArticleEntity articleInfo = articleService.getArticleSimpleInfo(String.valueOf(articleId));
    if (articleInfo == null) {
        return new ResponseEntity(404, "parameter error", "文章不存在");
    }
    MMSnsCommonUserEntity sessionCommonUser = (MMSnsCommonUserEntity) SecurityUtils.getSubject().getSession().getAttribute(MMSnsCommonUserEntity.MMSNS_COMMON_USER);
    Integer sessionCommonUserUserId = sessionCommonUser.getUserId();
    if (articleInfo.getUserId() == sessionCommonUserUserId.intValue()) {
        return new ResponseEntity(404, "parameter error", "不能點讚自己的文章");
    }
    List<MMSnsArticleVoteEntity> articleVotes = articleVoteService.getArticleVoteByCondition(articleId, sessionCommonUserUserId);
    if (articleVotes != null && articleVotes.size() > 0) {
        return new ResponseEntity(200, "success", "已點讚");
    }
    MMSnsArticleVoteEntity articleVoteEntity = new MMSnsArticleVoteEntity();
    articleVoteEntity.setArticleId(articleId);
    articleVoteEntity.setVoteUserId(sessionCommonUserUserId);
    articleVoteEntity.setVoteStatus(PublicEnum.NORMAL.value());
    articleVoteEntity.setVoteDate(new Date());
    articleVoteEntity.setArticleUserId(articleInfo.getUserId());
    articleVoteEntity = articleVoteService.voteArticle(articleVoteEntity);
    return new ResponseEntity(200, "success", "點讚成功");
}
 
開發者ID:babymm,項目名稱:mmsns,代碼行數:32,代碼來源:MMSnsPortalArticleVoteController.java

示例4: saveSession

import org.apache.shiro.SecurityUtils; //導入依賴的package包/類
/** 保存session */
private void saveSession(String account) {
	// 踢出用戶
	SysSession record = new SysSession();
	record.setAccount(account);
	List<?> sessionIds = sysSessionService.querySessionIdByAccount(record);
	if (sessionIds != null) {
		for (Object sessionId : sessionIds) {
			record.setSessionId((String) sessionId);
			sysSessionService.deleteBySessionId(record);
			sessionRepository.delete((String) sessionId);
			sessionRepository.cleanupExpiredSessions();
		}
	}
	Subject currentUser = SecurityUtils.getSubject();
	Session session = currentUser.getSession();
	record.setSessionId(session.getId().toString());
	String host = (String) session.getAttribute("HOST");
	record.setIp(StringUtils.isBlank(host) ? session.getHost() : host);
	record.setStartTime(session.getStartTimestamp());
	sysSessionService.update(record);
}
 
開發者ID:tb544731152,項目名稱:iBase4J,代碼行數:23,代碼來源:Realm.java

示例5: updateMember

import org.apache.shiro.SecurityUtils; //導入依賴的package包/類
/**
 * 更新組成員信息
 * @param userGroupId 用戶組和用戶關係主鍵id
 * @param privilage   權限
 * @param remark      描述
 * @param request
 * @return
 */
@ResponseBody
@RequiresPermissions("system:group:memberEdit")
@MumuLog(name = "用戶群組更新成員信息",operater = "PUT")
@RequestMapping(value = {"/memberEdit"}, method = RequestMethod.PUT)
public ResponseEntity updateMember(int userGroupId, String privilage, String remark, HttpServletRequest request) {
	try {
		SysUserGroup userGroup = new SysUserGroup();
		userGroup.setUserGroupId(userGroupId);
		userGroup.setEditor(SecurityUtils.getSubject().getPrincipal().toString());
		userGroup.setPrivilage(privilage);
		userGroup.setRemark(remark);
		userGroupService.updateSysUserGroupById(userGroup);
		return new ResponseEntity(200, "成功更新組成員信息", null);
	} catch (Exception e) {
		log.error(e);
		return new ResponseEntity(500, "編輯組成員信息出現異常", null);
	}
}
 
開發者ID:babymm,項目名稱:mumu,代碼行數:27,代碼來源:SystemGroupController.java

示例6: userGet

import org.apache.shiro.SecurityUtils; //導入依賴的package包/類
@RequestMapping("/userGet")
@ResponseBody
public String userGet(HttpServletRequest req,HttpServletResponse respon)throws Exception{
	Subject currentUser = SecurityUtils.getSubject();
	LOGGER.info("userinfo------->{}",JSON.toJSONString(currentUser.getPrincipal()));
	/*      String userNameString = req.getRemoteUser();  
          System.out.println("username---->"+userNameString);
        AttributePrincipal principal = (AttributePrincipal) req.getUserPrincipal();
        if (null != principal) {  
            Map<String, Object> attMap = principal.getAttributes();  
            for (Entry<String, Object> entry : attMap.entrySet()) {  
                System.out.println("===>     | " + entry.getKey() + "=:" + entry.getValue() + "<br>");  
            }         
            String username = null;  
            if (null != principal) {  
                username = principal.getName();  
                System.out.println("<span style='color:red;'>" + username + "</span><br>");  
            }  
        } */
	return (String) currentUser.getPrincipal();
}
 
開發者ID:hsj-xiaokang,項目名稱:springboot-shiro-cas-mybatis,代碼行數:22,代碼來源:UserController.java

示例7: loadShiroConfiguration

import org.apache.shiro.SecurityUtils; //導入依賴的package包/類
/**
 * Sets shiro configuration to the path of the resource
 * that points to the {@code shiro.ini} file.
 *
 * @param resource the resource
 */
public void loadShiroConfiguration(final Resource resource) {
    try {
        final Resource shiroResource = ResourceUtils.prepareClasspathResourceIfNeeded(resource);
        if (shiroResource != null && shiroResource.exists()) {
            final String location = shiroResource.getURI().toString();
            LOGGER.debug("Loading Shiro configuration from [{}]", location);

            final Factory<SecurityManager> factory = new IniSecurityManagerFactory(location);
            final SecurityManager securityManager = factory.getInstance();
            SecurityUtils.setSecurityManager(securityManager);
        } else {
            LOGGER.debug("Shiro configuration is not defined");
        }
    } catch (final Exception e) {
        throw Throwables.propagate(e);
    }
}
 
開發者ID:mrluo735,項目名稱:cas-5.1.0,代碼行數:24,代碼來源:ShiroAuthenticationHandler.java

示例8: index

import org.apache.shiro.SecurityUtils; //導入依賴的package包/類
/**
 * 
 * @return
 */
@RequestMapping(value = "index.html", method = RequestMethod.GET)
public String index(Model model) {
	try
	{
		// 獲取登錄的bean
		UserEntity userEntity = (UserEntity)SecurityUtils.getSubject().getPrincipal();
		List<ResourceEntity> list = resourceService.findResourcesMenuByUserId(userEntity.getId().intValue());
		List<ResourceEntity> treeList = TreeUtil.getChildResourceEntitys(list, null);
		model.addAttribute("list", treeList);
		model.addAttribute("menu", JSON.toJSONString(treeList));
		// 登陸的信息回傳頁麵
		model.addAttribute("userEntity", userEntity);
		return "/index";
	}catch(Exception e)
	{
		throw new SystemException(e);
	}
}
 
開發者ID:wjggwm,項目名稱:webside,代碼行數:23,代碼來源:IndexController.java

示例9: testIniRealm

import org.apache.shiro.SecurityUtils; //導入依賴的package包/類
/**
 * testIniRealm
 * @Description: iniRealm的測試
 * @return: void
 * @Author: BeautifulSoup
 * @Date: 2017年12月16日 上午11:41:43
 */
@Test
@Ignore
public void testIniRealm(){
	Factory<SecurityManager> factory=new IniSecurityManagerFactory("classpath:inirealm-shiro.ini");
	SecurityManager securityManager = factory.getInstance();
	SecurityUtils.setSecurityManager(securityManager);
	Subject subject = SecurityUtils.getSubject();
	UsernamePasswordToken token=new UsernamePasswordToken("james_shu", "1997admin");
	try{
		subject.login(token);
	}catch(AuthenticationException e){
		e.printStackTrace();
	}
	System.out.println("用戶認證狀態:"+subject.isAuthenticated());
	subject.logout();
	System.out.println("用戶當前認證狀態:"+subject.isAuthenticated());
}
 
開發者ID:fuyunwang,項目名稱:ShiroDemo,代碼行數:25,代碼來源:AuthenticationTest.java

示例10: hasAnyPermissions

import org.apache.shiro.SecurityUtils; //導入依賴的package包/類
/**
 * 驗證用戶是否具有以下任意一個權限。
 * @param permissions 以 delimeter 為分隔符的權限列表
 * @param delimeter 權限列表分隔符
 * @return 用戶是否具有以下任意一個權限
 */
public boolean hasAnyPermissions(String permissions, String delimeter) {
	Subject subject = SecurityUtils.getSubject();

	if (subject != null) {
		if (delimeter == null || delimeter.length() == 0) {
			delimeter = PERMISSION_NAMES_DELIMETER;
		}

		for (String permission : permissions.split(delimeter)) {
			if (permission != null && subject.isPermitted(permission.trim()) == true) {
				return true;
			}
		}
	}

	return false;
}
 
開發者ID:babymm,項目名稱:mmsns,代碼行數:24,代碼來源:ShiroPermissingTag.java

示例11: doGet

import org.apache.shiro.SecurityUtils; //導入依賴的package包/類
/**
 * lists the users in the system and their roles and renders the output as html file
 * @param job
 *            <code>MCRServletJob</code>
 * @exception IOException exception while rendering output
    * @exception TransformerException exception while rendering output
    * @exception SAXException exception while rendering output
    */
protected void doGet(MCRServletJob job) throws IOException, TransformerException, SAXException {
	org.apache.shiro.subject.Subject currentUser = SecurityUtils.getSubject();
	Element output;
	if (currentUser.hasRole("userAdmin")) {
       	output = prepareOutput(job,"userAdmin","admin","userManagement");
       	List<String> users = UserDAO.listUsers();
       	for (String user : users) {
       		Element userElement = new Element("user");
       		userElement.addContent(new Element("username").addContent(user));
       		List<UserRole> userRoles = UserRoleDAO.getUserRolesByEmail(user);
       		LOGGER.info("found " + userRoles.size() + " roles.");
       		for (UserRole userRole : userRoles) {
       			Element roleElement = new Element("role");
       			roleElement.addContent(userRole.getRoleName());
       			userElement.addContent(roleElement);
       		}
       		
       		output.addContent(userElement);
       	}
       } else
       	output = new Element("error").addContent(new Element("message").addContent("error.noPermission"));
	sendOutput(job,output);
}
 
開發者ID:ETspielberg,項目名稱:bibliometrics,代碼行數:32,代碼來源:UserManagementServlet.java

示例12: doGetPost

import org.apache.shiro.SecurityUtils; //導入依賴的package包/類
public void doGetPost(MCRServletJob job) throws Exception {
    HttpServletRequest req = job.getRequest();
    String path = job.getRequest().getPathInfo().substring(1);
    LOGGER.info(path);
    boolean b = tryLogin(path.substring(0, 6), path.substring(6), false);
    if (b) {
        org.apache.shiro.subject.Subject currentUser = SecurityUtils.getSubject();
        if (currentUser.hasRole("client")) {
            String hash = req.getUserPrincipal().getName();
            File reportFile = new File(resultsDir + "/" + hash.substring(0, 6), "report.xml");
            SAXBuilder builder = new SAXBuilder();
            Document document = builder.build(reportFile);
            getLayoutService().doLayout(job.getRequest(), job.getResponse(), new MCRJDOMContent(document));
            }
    }
}
 
開發者ID:ETspielberg,項目名稱:bibliometrics,代碼行數:17,代碼來源:BibliometricReportDisplayServlet.java

示例13: submitApproval

import org.apache.shiro.SecurityUtils; //導入依賴的package包/類
protected boolean submitApproval() throws IOException, OAuthSystemException {
    if (isPost() && !clientDetails().trusted()) {
        //submit approval
        final HttpServletRequest request = oauthRequest.request();
        final String oauthApproval = request.getParameter(REQUEST_USER_OAUTH_APPROVAL);
        if (!"true".equalsIgnoreCase(oauthApproval)) {
            //Deny action
            LOG.debug("User '{}' deny access", SecurityUtils.getSubject().getPrincipal());
            responseApprovalDeny();
            return true;
        } else {
            userFirstApproved = true;
            return false;
        }
    }
    return false;
}
 
開發者ID:monkeyk,項目名稱:oauth2-shiro,代碼行數:18,代碼來源:AbstractAuthorizeHandler.java

示例14: responseApprovalDeny

import org.apache.shiro.SecurityUtils; //導入依賴的package包/類
protected void responseApprovalDeny() throws IOException, OAuthSystemException {

        final OAuthResponse oAuthResponse = OAuthASResponse.errorResponse(HttpServletResponse.SC_FOUND)
                .setError(OAuthError.CodeResponse.ACCESS_DENIED)
                .setErrorDescription("User denied access")
                .location(clientDetails().getRedirectUri())
                .setState(oauthRequest.getState())
                .buildQueryMessage();
        LOG.debug("'ACCESS_DENIED' response: {}", oAuthResponse);

        WebUtils.writeOAuthQueryResponse(response, oAuthResponse);

        //user logout when deny
        final Subject subject = SecurityUtils.getSubject();
        subject.logout();
        LOG.debug("After 'ACCESS_DENIED' call logout. user: {}", subject.getPrincipal());
    }
 
開發者ID:monkeyk,項目名稱:oauth2-shiro,代碼行數:18,代碼來源:AbstractAuthorizeHandler.java

示例15: doGetAuthenticationInfo

import org.apache.shiro.SecurityUtils; //導入依賴的package包/類
@Override
protected AuthenticationInfo doGetAuthenticationInfo(AuthenticationToken token) throws AuthenticationException {
    //獲取用戶的輸入的賬號.
    String username = (String)token.getPrincipal();
    User user = userService.findByUserId(username);
    if(user==null) throw new UnknownAccountException();
    SimpleAuthenticationInfo authenticationInfo = new SimpleAuthenticationInfo(
            user, //用戶
            user.getPassword(), //密碼
            ByteSource.Util.bytes(username),
            getName()  //realm name
    );
    // 當驗證都通過後,把用戶信息放在session裏
    Session session = SecurityUtils.getSubject().getSession();
    session.setAttribute("userSession", user);
    session.setAttribute("userSessionId", user.getLoginId());
    return authenticationInfo;
}
 
開發者ID:ju5t1nhhh,項目名稱:CMSdemo,代碼行數:19,代碼來源:MyShiroRealm.java


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