Shiro——入门Demo
环境- 引入相关maven依赖, shiro-core,commons-logging
配置shiro配置文件:ini后缀
主方法测试:
import org.apache.shiro.SecurityUtils; import org.apache.shiro.authc.UsernamePasswordToken; import org.apache.shiro.mgt.DefaultSecurityManager; import org.apache.shiro.realm.text.IniRealm; import org.apache.shiro.subject.Subject; import org.apache.shiro.util.Factory; /** * @author DeepSleeping * @date 2019/5/27 11:45 * @description */ public class Main { public static void main(String[] args) { DefaultSecurityManager defaultSecurityManager = new DefaultSecurityManager(); IniRealm iniRealm = new IniRealm("classpath:shiro/shiro.ini"); defaultSecurityManager.setRealm(iniRealm); SecurityUtils.setSecurityManager(defaultSecurityManager); Subject subject = SecurityUtils.getSubject(); UsernamePasswordToken usernamePasswordToken = new UsernamePasswordToken("admin", "123456"); subject.login(usernamePasswordToken); System.out.println(subject.isAuthenticated()); } }
那个iniSecurity啥的Factory过期了,查了资料后这样写的。
可以在登录捕获异常,比如unknownusername,啥的针对不同异常做不同处理。