shiro学习总结

shiro内容主要有两大部分:认证(你之前登录了没)和授权(你有没有权限访问这个接囗)

认证的原理过滤器Filter,入囗DelegatingFilterProxy,spring的一个过滤器

DelegatingFilterProxy->ShiroFilterFactoryBean->自定义过滤器(也可使用shiro自带过滤器)->subject.login()

shiro学习总结
shiro学习总结

授权的原理springAop实现的代理(现在都用注解来配置),引入AuthorizationAttributeSourceAdvisor

AuthorizationAttributeSourceAdvisor->PermissionAnnotationHandler.assertAuthorized()->subject.checkPermissions()

之前画图用了subject.isPermitted(),图就不改了,两个方法也没啥区别
shiro学习总结
shiro学习总结
总之最后都会调用自定义的realm类,我们在这个类要重写两个方法:

getAuthenticationInfo():用来认证,内容:判断请示的token是否过期,不过期就续期并返回用户信息

getAuthorizationInfo():用来鉴权,内容:查出用户的所有权限,然后返回

内容一般就是这样了,根据业务来写,可能会不一样。

原理其实就是约定编程,约定先走哪些过程,再走哪些过程。

过滤器,拦截器,通知,这些的本质其实就是约定编程。

上一篇:asp.net用户身份验证时读不到用户信息的问题 您的登录尝试不成功。请重试。 Login控件


下一篇:如何书写高质量的jQuery代码