SpringBoot基于Shiro處理ajax請求代碼實例
更新時間:2020年06月08日 08:35:32 作者:絕對密位
這篇文章主要介紹了SpringBoot基于Shiro處理ajax請求代碼實例,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
寫一個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數(shù)據(jù)就行 HttpServletRequest req = (HttpServletRequest) request; if ("XMLHttpRequest".equals(req.getHeader("X-Requested-With"))) { // 獲取到當(dāng)前的登錄對象 如果是沒有經(jīng)過認(rèn)證的用戶就獲取不到認(rèn)證信息 Subject subject = SecurityUtils.getSubject(); if (subject.getPrincipal() == null) { HttpServletResponse resp = (HttpServletResponse) response; // 設(shè)置響應(yīng)類型和編碼字符 不然中文亂碼 resp.setContentType("application/json;charset=utf-8"); resp.setCharacterEncoding("UTF-8"); // Message是我寫的一個包裝類,用來向前臺返回數(shù)據(jù) resp.getWriter().write(JSON.toJSONString(Message.failed("請登錄后操作"))); return false; } else { // 經(jīng)過認(rèn)證的話就放過去 讓下一個過濾器處理 return true; } } else { // 不是ajax請求的話也放過去 讓下一個過濾器處理 return true; } } }
Shiro的配置類里面的配置我就全部放出來了 就看一下與這次配置相關(guān)的
@Bean(name = "shiroFilter") public ShiroFilterFactoryBean shiroFilterFactoryBean(SecurityManager securityManager) { ShiroFilterFactoryBean factoryBean = new ShiroFilterFactoryBean(); factoryBean.setSecurityManager(securityManager); // 設(shè)置登錄界面URL factoryBean.setLoginUrl(loginUrl); // 設(shè)置未經(jīng)認(rèn)證頁面的URL factoryBean.setUnauthorizedUrl(unauthorizedUrl); // 這里是設(shè)置過濾器 // 要注意 如果你沒寫的話默認(rèn)是有一個FormAuthenticationFilter // 如果你手動設(shè)置了過濾器會覆蓋掉默認(rèn)設(shè)置 // 在這里加上就好了 HashMap<String, Filter> filter = new HashMap<>(); filter.put("authc", new AjaxFilter()); filter.put("authc", new FormAuthenticationFilter()); factoryBean.setFilters(filter); // 需要認(rèn)證的加到authc里面 // 不需要認(rèn)證的加到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和網(wǎng)頁請求都能正常處理了
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
您可能感興趣的文章:
- jquery+ajaxform+springboot控件實現(xiàn)數(shù)據(jù)更新功能
- SpringBoot解決ajax跨域問題的方法
- Springboot解決ajax+自定義headers的跨域請求問題
- SpringBoot結(jié)合Ajax實現(xiàn)登錄頁面實例
- AJAX?SpringBoot?前后端數(shù)據(jù)交互的項目實現(xiàn)
- SpringBoot+Hutool+thymeleaf完成導(dǎo)出Excel的實現(xiàn)方法
- SpringBoot + thymeleaf 實現(xiàn)讀取視頻列表并播放視頻功能
- springboot如何使用thymeleaf完成頁面緩存
- SpringBoot+Thymeleaf+ECharts實現(xiàn)大數(shù)據(jù)可視化(基礎(chǔ)篇)
- 在SpringBoot中配置Thymeleaf的模板路徑方式
- SpringBoot+thymeleaf+ajax實現(xiàn)局部刷新詳情
相關(guān)文章
Java基于正則表達(dá)式實現(xiàn)的替換匹配文本功能【經(jīng)典實例】
這篇文章主要介紹了Java基于正則表達(dá)式實現(xiàn)的替換匹配文本功能,結(jié)合完整實例形式分析了java字符串正則替換操作技巧,需要的朋友可以參考下2017-04-04SpringBoot整合SpringBoot-Admin實現(xiàn)監(jiān)控應(yīng)用功能
本文主要介紹如何整合Spring Boot Admin,以此監(jiān)控Springboot應(yīng)用,文中有相關(guān)的示例代碼供大家參考,需要的朋友可以參考下2023-05-05解決Maven parent.relativePath帶給我的坑
在Linux環(huán)境下使用Maven進(jìn)行項目打包時,可能會遇到“當(dāng)前目錄沒有pom文件”的錯誤,需要確認(rèn)在包含pom.xml文件的項目目錄下執(zhí)行Maven命令,另外,如果遇到“parent.relativePath points at wrong local POM”錯誤,可能是父模塊依賴問題2024-09-09SpringBoot Shiro授權(quán)實現(xiàn)過程解析
這篇文章主要介紹了SpringBoot Shiro授權(quán)實現(xiàn)過程解析,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下2019-11-11Java 中二進(jìn)制轉(zhuǎn)換成十六進(jìn)制的兩種實現(xiàn)方法
這篇文章主要介紹了Java 中二進(jìn)制轉(zhuǎn)換成十六進(jìn)制的兩種實現(xiàn)方法的相關(guān)資料,需要的朋友可以參考下2017-06-06