* added updated example codes * updated example code StringToCharStream * deleted StringToCharStream.java locally * removed redundant file * added code for apache commons collection SetUtils * refactored example code * added example code for bytebuddy * added example code for PCollections * update pom * refactored tests for PCollections * spring security xml config * spring security xml config * remove redundant comment * example code for apache-shiro * Fixed indentation. * Fix formatting issues
85 lines
2.8 KiB
Java
85 lines
2.8 KiB
Java
package com.baeldung;
|
|
|
|
import org.apache.shiro.SecurityUtils;
|
|
import org.apache.shiro.authc.*;
|
|
import org.apache.shiro.config.IniSecurityManagerFactory;
|
|
import org.apache.shiro.mgt.SecurityManager;
|
|
import org.apache.shiro.session.Session;
|
|
import org.apache.shiro.subject.Subject;
|
|
import org.apache.shiro.util.Factory;
|
|
import org.slf4j.Logger;
|
|
import org.slf4j.LoggerFactory;
|
|
|
|
public class Main {
|
|
private static final transient Logger log = LoggerFactory.getLogger(Main.class);
|
|
|
|
public static void main(String[] args) {
|
|
|
|
Factory<SecurityManager> factory
|
|
= new IniSecurityManagerFactory("classpath:shiro.ini");
|
|
SecurityManager securityManager = factory.getInstance();
|
|
|
|
SecurityUtils.setSecurityManager(securityManager);
|
|
Subject currentUser = SecurityUtils.getSubject();
|
|
|
|
if (!currentUser.isAuthenticated()) {
|
|
UsernamePasswordToken token
|
|
= new UsernamePasswordToken("user", "password");
|
|
token.setRememberMe(true);
|
|
try {
|
|
currentUser.login(token);
|
|
} catch (UnknownAccountException uae) {
|
|
log.error("Username Not Found!", uae);
|
|
} catch (IncorrectCredentialsException ice) {
|
|
log.error("Invalid Credentials!", ice);
|
|
} catch (LockedAccountException lae) {
|
|
log.error("Your Account is Locked!", lae);
|
|
} catch (AuthenticationException ae) {
|
|
log.error("Unexpected Error!", ae);
|
|
}
|
|
}
|
|
|
|
log.info("User [" + currentUser.getPrincipal() + "] logged in successfully.");
|
|
|
|
if (currentUser.hasRole("admin")) {
|
|
log.info("Welcome Admin");
|
|
} else if(currentUser.hasRole("editor")) {
|
|
log.info("Welcome, Editor!");
|
|
} else if(currentUser.hasRole("author")) {
|
|
log.info("Welcome, Author");
|
|
} else {
|
|
log.info("Welcome, Guest");
|
|
}
|
|
|
|
if(currentUser.isPermitted("articles:compose")) {
|
|
log.info("You can compose an article");
|
|
} else {
|
|
log.info("You are not permitted to compose an article!");
|
|
}
|
|
|
|
if(currentUser.isPermitted("articles:save")) {
|
|
log.info("You can save articles");
|
|
} else {
|
|
log.info("You can not save articles");
|
|
}
|
|
|
|
if(currentUser.isPermitted("articles:publish")) {
|
|
log.info("You can publish articles");
|
|
} else {
|
|
log.info("You can not publish articles");
|
|
}
|
|
|
|
Session session = currentUser.getSession();
|
|
session.setAttribute("key", "value");
|
|
String value = (String) session.getAttribute("key");
|
|
if (value.equals("value")) {
|
|
log.info("Retrieved the correct value! [" + value + "]");
|
|
}
|
|
|
|
currentUser.logout();
|
|
|
|
System.exit(0);
|
|
}
|
|
|
|
}
|