本文整理匯總了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;
}
示例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);
}
}
示例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", "點讚成功");
}
示例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);
}
示例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);
}
}
示例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();
}
示例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);
}
}
示例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);
}
}
示例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());
}
示例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;
}
示例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);
}
示例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));
}
}
}
示例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;
}
示例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());
}
示例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;
}