<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
首先從使用者端發來的所有請求都經過Shiro過濾器,如果使用者沒有認證的都打回去進行認證,認證成功的,再判斷是否具有存取某類資源(公有資源,私有資源)的許可權,如果沒有許可權,存取失敗;如果有許可權存取成功。注意:使用者端傳來的token要和realm中的認證資訊進行相同規則的比較(加密演演算法要一致)。
常見過濾器:
1、在shiro設定類中設定,使用 filterFactoryBean.setFilterChainDefinitionMa()
簡單的設定過濾規則
@Bean public ShiroFilterFactoryBean getShiroFilterFactoryBean(DefaultWebSecurityManager defaultWebSecurityManager) { // 建立ShiroFilterFactoryBean ShiroFilterFactoryBean filterFactoryBean = new ShiroFilterFactoryBean(); //設定安全管理器 filterFactoryBean.setSecurityManager(defaultWebSecurityManager); //設定受限資源,index是受限資源,authc Map<String, String> map = new HashMap<String, String>(); // /**代表匹配所有url map.put("/**", "authc"); // /user/login 是可以匿名存取的也就是公有資源 map.put("/user/login", "anon"); filterFactoryBean.setFilterChainDefinitionMap(map); // 設定預設認證路徑 其實shiro預設的認證路徑就是login.jsp filterFactoryBean.setLoginUrl("/login.jsp"); return filterFactoryBean; }
2、重寫shiro提供的過濾器
重寫角色許可權的過濾器
public class MyAuthorizationFilter extends RolesAuthorizationFilter { @Override public boolean isAccessAllowed(ServletRequest request, ServletResponse response, Object mappedValue) throws IOException { boolean allowed =super.isAccessAllowed(request, response, mappedValue); if (!allowed) { String method = WebUtils.toHttp(request).getMethod(); if (StringUtils.equalsIgnoreCase("OPTIONS", method)) { return true; } } return allowed; } @Override protected boolean onAccessDenied(ServletRequest request, ServletResponse response) throws IOException { HttpServletRequest req = (HttpServletRequest) request; HttpServletResponse resp = (HttpServletResponse) response; if (req.getMethod().equals(RequestMethod.OPTIONS.name())) { resp.setStatus(HttpStatus.OK.value()); return true; } // 前端Ajax請求時requestHeader裡面帶一些引數,用於判斷是否是前端的請求 String ajaxHeader = req.getHeader(CustomSessionManager.AUTHORIZATION); if (StringUtils.isNotBlank(ajaxHeader)) { // 前端Ajax請求,則不會重定向 resp.setHeader("Access-Control-Allow-Origin", req.getHeader("Origin")); resp.setHeader("Access-Control-Allow-Credentials", "true"); resp.setContentType("application/json; charset=utf-8"); resp.setCharacterEncoding("UTF-8"); PrintWriter out = resp.getWriter(); String result = "{"MESSAGE":"角色,許可權不足"}"; out.println(result); out.flush(); out.close(); return false; } return super.onAccessDenied(request, response); } }
shiro設定類設定過濾器
//Filter工廠,設定對應的過濾條件和跳轉條件 @Bean public ShiroFilterFactoryBean shiroFilterFactoryBean(SecurityManager securityManager) { ShiroFilterFactoryBean shiroFilterFactoryBean = new ShiroFilterFactoryBean(); shiroFilterFactoryBean.setSecurityManager(securityManager); Map<String, String> map = new HashMap<>(); //登出 map.put("/logout", "logout"); //對所有使用者認證 map.put("/**", "authc"); //登入 log.info("loginUrl:" + loginUrl); shiroFilterFactoryBean.setLoginUrl(loginUrl); // //首頁 // shiroFilterFactoryBean.setSuccessUrl("/index"); //錯誤頁面,認證不通過跳轉 shiroFilterFactoryBean.setUnauthorizedUrl("/error"); shiroFilterFactoryBean.setFilterChainDefinitionMap(map); /* 自定義filter註冊 */ Map<String, Filter> filters = shiroFilterFactoryBean.getFilters(); //根據上面列表中的過濾器的名稱設定 filters.put("roles", new MyAuthorizationFilter()); return shiroFilterFactoryBean; }
注意:過濾器需要根據上面列表中的過濾器的名稱設定
除了在設定類中設定路徑的存取許可權之外,還可以使用註解來控制許可權 。
Shiro註解一共有五個:
一般情況下我們在專案中做許可權控制,使用最多的是RequiresPermissions和RequiresRoles,允許存在多個角色和許可權,預設邏輯是AND,也就是同時擁有這些才可以存取方法,可以在註解中以引數的形式設定成OR。作用在controller類的方法上。
// 範例 //擁有一個角色就可以存取 @RequiresRoles(value={"ADMIN","USER"},logical = Logical.OR) //擁有所有許可權才可以存取 @RequiresPermissions(value={"sys:user:info","sys:role:info"},logical = Logical.AND)
使用順序:Shiro註解是存在順序的,當多個註解在一個方法上的時候,會逐個檢查,知道全部通過為止,預設攔截順序是:
RequiresRoles->RequiresPermissions->RequiresAuthentication->RequiresUser->RequiresGuest
這裡指的是動態設定當前登入使用者的許可權
1、登入時查詢當前使用者的角色、許可權
/** * 賦予角色和許可權:使用者進行許可權驗證時 Shiro會去快取中找,如果查不到資料,會執行這個方法去查許可權,並放入快取中 */ @Override protected AuthorizationInfo doGetAuthorizationInfo(PrincipalCollection principalCollection) { SimpleAuthorizationInfo authorizationInfo = new SimpleAuthorizationInfo(); // 獲取使用者 User user = (User) principalCollection.getPrimaryPrincipal(); Integer userId =user.getId(); // 這裡可以進行授權和處理 Set<String> rolesSet = new HashSet<>(); Set<String> permsSet = new HashSet<>(); // 獲取當前使用者對應的許可權(這裡根據業務自行查詢) List<Role> roleList = roleMapper.selectRoleByUserId( userId ); for (Role role:roleList) { rolesSet.add( role.getCode() ); List<Menu> menuList = menuMapper.selectMenuByRoleId( role.getId() ); for (Menu menu :menuList) { permsSet.add( menu.getResources() ); } } //將查到的許可權和角色分別傳入authorizationInfo中 authorizationInfo.setStringPermissions(permsSet); authorizationInfo.setRoles(rolesSet); log.info("--------------- 賦予角色和許可權成功! ---------------"); return authorizationInfo; }
2、當用戶許可權發生改變時,需要重新退出登陸重新整理許可權。
不需要重新登陸實現許可權重新整理,參考此篇
到此這篇關於SpringBoot詳解shiro過濾器與許可權控制的文章就介紹到這了,更多相關SpringBoot shiro過濾器 內容請搜尋it145.com以前的文章或繼續瀏覽下面的相關文章希望大家以後多多支援it145.com!
相關文章
<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
综合看Anker超能充系列的性价比很高,并且与不仅和iPhone12/苹果<em>Mac</em>Book很配,而且适合多设备充电需求的日常使用或差旅场景,不管是安卓还是Switch同样也能用得上它,希望这次分享能给准备购入充电器的小伙伴们有所
2021-06-01 09:31:42
除了L4WUDU与吴亦凡已经多次共事,成为了明面上的厂牌成员,吴亦凡还曾带领20XXCLUB全队参加2020年的一场音乐节,这也是20XXCLUB首次全员合照,王嗣尧Turbo、陈彦希Regi、<em>Mac</em> Ova Seas、林渝植等人全部出场。然而让
2021-06-01 09:31:34
目前应用IPFS的机构:1 谷歌<em>浏览器</em>支持IPFS分布式协议 2 万维网 (历史档案博物馆)数据库 3 火狐<em>浏览器</em>支持 IPFS分布式协议 4 EOS 等数字货币数据存储 5 美国国会图书馆,历史资料永久保存在 IPFS 6 加
2021-06-01 09:31:24
开拓者的车机是兼容苹果和<em>安卓</em>,虽然我不怎么用,但确实兼顾了我家人的很多需求:副驾的门板还配有解锁开关,有的时候老婆开车,下车的时候偶尔会忘记解锁,我在副驾驶可以自己开门:第二排设计很好,不仅配置了一个很大的
2021-06-01 09:30:48
不仅是<em>安卓</em>手机,苹果手机的降价力度也是前所未有了,iPhone12也“跳水价”了,发布价是6799元,如今已经跌至5308元,降价幅度超过1400元,最新定价确认了。iPhone12是苹果首款5G手机,同时也是全球首款5nm芯片的智能机,它
2021-06-01 09:30:45