SpringBoot基于Shiro處理ajax請求代碼實例
更新時間:2020年06月08日 08:35:32 作者:絕對密位
這篇文章主要介紹了SpringBoot基于Shiro處理ajax請求代碼實例,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
寫一個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和網頁請求都能正常處理了
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
您可能感興趣的文章:
- jquery+ajaxform+springboot控件實現數據更新功能
- SpringBoot解決ajax跨域問題的方法
- Springboot解決ajax+自定義headers的跨域請求問題
- SpringBoot結合Ajax實現登錄頁面實例
- AJAX?SpringBoot?前后端數據交互的項目實現
- SpringBoot+Hutool+thymeleaf完成導出Excel的實現方法
- SpringBoot + thymeleaf 實現讀取視頻列表并播放視頻功能
- springboot如何使用thymeleaf完成頁面緩存
- SpringBoot+Thymeleaf+ECharts實現大數據可視化(基礎篇)
- 在SpringBoot中配置Thymeleaf的模板路徑方式
- SpringBoot+thymeleaf+ajax實現局部刷新詳情
相關文章
SpringBoot整合SpringBoot-Admin實現監(jiān)控應用功能
本文主要介紹如何整合Spring Boot Admin,以此監(jiān)控Springboot應用,文中有相關的示例代碼供大家參考,需要的朋友可以參考下2023-05-05
解決Maven parent.relativePath帶給我的坑
在Linux環(huán)境下使用Maven進行項目打包時,可能會遇到“當前目錄沒有pom文件”的錯誤,需要確認在包含pom.xml文件的項目目錄下執(zhí)行Maven命令,另外,如果遇到“parent.relativePath points at wrong local POM”錯誤,可能是父模塊依賴問題2024-09-09

