51,412
社区成员
发帖
与我相关
我的任务
分享@Bean
public ShiroFilterFactoryBean shiroFilter (SecurityManager securityManager) {
System.out.println("ShiroConfiguration.shirFilter()");
ShiroFilterFactoryBean shiroFilterFactoryBean = new ShiroFilterFactoryBean();
shiroFilterFactoryBean.setSecurityManager(securityManager);
// 登录成功后要跳转的链接
//Map filters = shiroFilterFactoryBean.getFilters();
//filters.put("authc" , new com.example.common.shiro.AuthenticationFilter());
// 如果不设置默认会自动寻找Web工程根目录下的"/login.jsp"页面
shiroFilterFactoryBean.setLoginUrl("/login");
//登录成功后需要走的方法
shiroFilterFactoryBean.setSuccessUrl("/search");
//拦截器
Map<String,String> filterChainDefinitionMap = new LinkedHashMap<>();
// 配置不会被拦截的链接 顺序判断
filterChainDefinitionMap.put("/ajaxLogin", "anon");
filterChainDefinitionMap.put("/search", "anon");
//配置退出过滤器,其中具体的退出代码shiro已经替我们实现了
filterChainDefinitionMap.put("/logout" , "logout");
//authc:所有url都必须认证通过才可以访问; anon:所有url都都可以匿名访问 ,这个一定要放到最后
filterChainDefinitionMap.put("/**", "authc");
shiroFilterFactoryBean.setFilterChainDefinitionMap(filterChainDefinitionMap);
return shiroFilterFactoryBean;
}
@Bean
public MyShiroRealm myShiroRealm(){
MyShiroRealm myShiroRealm = new MyShiroRealm();
return myShiroRealm;
}
@Bean
public SecurityManager securityManager(){
DefaultWebSecurityManager securityManager = new DefaultWebSecurityManager();
securityManager.setRealm(myShiroRealm());
return securityManager;
}
@Bean
public DefaultAdvisorAutoProxyCreator advisorAutoProxyCreator(){
DefaultAdvisorAutoProxyCreator creator = new DefaultAdvisorAutoProxyCreator();
creator.setProxyTargetClass(true);
return creator;
}@Component
@WebFilter(urlPatterns = "/*" , filterName = "authenticationFilter")
public class AuthenticationFilter extends FormAuthenticationFilter {
@Override
protected boolean onLoginSuccess(AuthenticationToken token, Subject subject, ServletRequest request, ServletResponse response) throws Exception {
String successUrl = "/search";
WebUtils.getAndClearSavedRequest(request);
WebUtils.issueRedirect(request,response,successUrl);
return false;
}
/**
* SpringBoot 提供了 FilterRegistrationBean 方便我们对 Filter 进行管理。 将不需要注册的 Filter 注入方法。 不然会报错
* @param filter
* @return
*/
@Bean
public FilterRegistrationBean registration (com.example.common.shiro.AuthenticationFilter filter) {
FilterRegistrationBean registration = new FilterRegistrationBean(filter);
registration.setEnabled(false);
return registration;
}
}
subject.login(token);//登录验证
if (subject.isAuthenticated()){
return "index";
}else{
return "view/login";
}
就是不跳转<!-- shiro拦截器 -->
<bean id="shiroFilter" class="org.apache.shiro.spring.web.ShiroFilterFactoryBean">
<!-- 安全管理器 -->
<property name="securityManager" ref="securityManager"/>
<!-- 注入登录页面访问URL -->
<property name="loginUrl" value="/login"/>
<!-- 权限认证成功,则跳转到指定页面 -->
<!--<property name="successUrl" value="/s/index"/>-->
<!-- 权限认证失败,则跳转到指定页面 -->
<property name="unauthorizedUrl" value="/login"/>
<!-- shiro权限配置 -->
<property name="filterChainDefinitions">
<value>
<!-- anon表示此地址不需要任何权限即可访问 -->
<!-- 引入静态资源文件 -->
/css/** = anon
/verifyCode = anon
/fonts/** = anon
/images/** = anon
/js/** = anon
<!--所有的请求(除去配置的静态资源请求或请求地址为anon的请求)都要通过登录验证,如果未登录则跳到/login-->
/** = authc
/logout = logout
</value>
</property>
</bean>