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)文章
spring cloud 集成 ribbon負(fù)載均衡的實例代碼
spring Cloud Ribbon 是一個客戶端的負(fù)載均衡器,它提供對大量的HTTP和TCP客戶端的訪問控制。本文給大家介紹spring cloud 集成 ribbon負(fù)載均衡,感興趣的朋友跟隨小編一起看看吧2021-11-11
spring?boot整合mongo查詢converter異常排查記錄
這篇文章主要為大家介紹了spring?boot整合mongo查詢時拋出converter異常的排查解決記錄,有需要的朋友可以借鑒參考下,希望能夠有所幫助2022-03-03
Java實現(xiàn)ArrayList自動擴(kuò)容
ArrayList的擴(kuò)容規(guī)則是非常簡單的,它會根據(jù)需要自動擴(kuò)容,本文就來介紹一下Java實現(xiàn)ArrayList自動擴(kuò)容,具有一定的參考價值,感興趣的可以了解一下2023-12-12
IDEA+maven+SpringBoot+JPA+Thymeleaf實現(xiàn)Crud及分頁
這篇文章主要介紹了不需要電腦任何操作基于IDEA + maven + SpringBoot + JPA + Thymeleaf實現(xiàn)CRUD及分頁,需要的朋友可以參考下2018-03-03
Java使用itextpdf找出PDF中文字的坐標(biāo)
這篇文章主要為大家詳細(xì)介紹了Java如果使用itextpdf找出PDF中文字的坐標(biāo),文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2025-01-01
Java日期轉(zhuǎn)換注解配置date?format時間失效
這篇文章主要為大家介紹了Java日期轉(zhuǎn)換注解配置date?format時間失效,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-12-12

