Subject是怎么创建的
首先前面讲了,shiro其实就是一连串的过滤器链,过滤器链的话就是依次执行doFilter方法:我们直接找doFilter的shiro包的实现:
注意,spring包也有个叫做OncePerRequestFilter的类;
Subject创建入口
我们看OncePerRequestFilter这个类的doFilter方法,是final的,不会被覆写,然后就执行doFilterInternal,还记得第一次请求当时传进来的是什么类吗?是AbstractShiroFilter
我们看doFilterInternal的实现:
具体创建subject方法
我们直接到具体创建的方法,看源码直接点进去就好了:
最后是DefaultSecurityManager方法调用的createSubject
就是通过DefaultSecurityManager通过SubjectContext来创建的,SubjectContext的具体实现就是相当于内部维护了个map,然后和用户的各种信息:
然后通过各种解析,赋值,赋值SecurityManager,session,登录信息最后通过
返回Subject
DefaultWebSubjectFactory的SUbject工厂类创建出Subject;至此创建结束;