午夜剧场伦理_日本一道高清_国产又黄又硬_91黄色网战_女同久久另类69精品国产_妹妹的朋友在线

您的位置:首頁技術文章
文章詳情頁

SpringBoot基于Shiro處理ajax請求代碼實例

瀏覽:153日期:2023-05-13 18:05:05

寫一個Shiro的過濾器

import cn.erika.demo.common.model.vo.Message;import com.alibaba.fastjson.JSON;import org.apache.shiro.SecurityUtils;import org.apache.shiro.subject.Subject;import org.apache.shiro.web.servlet.AdviceFilter;import javax.servlet.ServletRequest;import javax.servlet.ServletResponse;import javax.servlet.http.HttpServletRequest;import javax.servlet.http.HttpServletResponse;/** * Ajax請求處理 用于前后臺分離的場景 */public class AjaxFilter extends AdviceFilter { @Override protected boolean preHandle(ServletRequest request, ServletResponse response) throws Exception { // 先判斷是不是ajax請求 ajax請求都會自帶一個請求頭X-Requested-With // 如果有值而且是XMLHttpRequest那就可以確定是個ajax請求 返回json數據就行 HttpServletRequest req = (HttpServletRequest) request; if ('XMLHttpRequest'.equals(req.getHeader('X-Requested-With'))) { // 獲取到當前的登錄對象 如果是沒有經過認證的用戶就獲取不到認證信息 Subject subject = SecurityUtils.getSubject(); if (subject.getPrincipal() == null) {HttpServletResponse resp = (HttpServletResponse) response;// 設置響應類型和編碼字符 不然中文亂碼resp.setContentType('application/json;charset=utf-8');resp.setCharacterEncoding('UTF-8');// Message是我寫的一個包裝類,用來向前臺返回數據resp.getWriter().write(JSON.toJSONString(Message.failed('請登錄后操作')));return false; } else {// 經過認證的話就放過去 讓下一個過濾器處理return true; } } else { // 不是ajax請求的話也放過去 讓下一個過濾器處理 return true; } }}

Shiro的配置類里面的配置我就全部放出來了 就看一下與這次配置相關的

@Bean(name = 'shiroFilter')public ShiroFilterFactoryBean shiroFilterFactoryBean(SecurityManager securityManager) { ShiroFilterFactoryBean factoryBean = new ShiroFilterFactoryBean(); factoryBean.setSecurityManager(securityManager); // 設置登錄界面URL factoryBean.setLoginUrl(loginUrl); // 設置未經認證頁面的URL factoryBean.setUnauthorizedUrl(unauthorizedUrl); // 這里是設置過濾器 // 要注意 如果你沒寫的話默認是有一個FormAuthenticationFilter // 如果你手動設置了過濾器會覆蓋掉默認設置 // 在這里加上就好了 HashMap<String, Filter> filter = new HashMap<>(); filter.put('authc', new AjaxFilter()); filter.put('authc', new FormAuthenticationFilter()); factoryBean.setFilters(filter); // 需要認證的加到authc里面 // 不需要認證的加到anon里面 HashMap<String, String> filterChain = new HashMap<>(); filterChain.put('/favicon.ico', 'anon'); filterChain.put('/login', 'anon'); filterChain.put('/logout', 'logout'); filterChain.put('/**', 'authc'); factoryBean.setFilterChainDefinitionMap(filterChain); return factoryBean;}

這樣ajax和網頁請求都能正常處理了

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持好吧啦網。

標簽: Spring
相關文章:
主站蜘蛛池模板: 欧美毛片网站 | 国产亚洲精品精品精品 | 久久澡| 自拍在线 | 精品国产乱码久久久久久蜜臀网站 | 欧美色拍| 中国妇女裸体交性大片 | 手机在线一区 | 高清成人综合 | 天天干天天干天天干天天 | 国产精品久久久久av | 精品一区二区三区中文字幕 | 亚洲天堂一区在线观看 | 天堂网在线观看 | 精品国产毛片 | 天天综合一区 | 三级国产视频 | 第一福利在线视频 | 男人午夜免费视频 | 日韩欧美无 | 制服丨自拍丨欧美丨动漫丨 | 日本天天色 | 青草av在线| 亚洲精品色图 | 最近中文字幕第一页 | 免费成人激情视频 | 91精品福利视频 | 大地资源中文在线观看免费版 | 久久久久久久久久国产 | 精品一级视频 | 欧美日韩亚洲国产综合 | 美女黄色在线观看 | 成人在线免费看片 | 涩涩网站在线观看 | 日日舔 | 伊人网在线视频 | 国产一区精品视频 | 97超视频| 欧美日韩一区二区在线播放 | 波多野结衣毛片 | 91热热|