這篇文章主要為大家展示了用代碼解析SpringBoot基于Shiro處理ajax請(qǐng)求,內(nèi)容簡(jiǎn)而易懂,希望大家可以學(xué)習(xí)一下,學(xué)習(xí)完之后肯定會(huì)有收獲的,下面讓小編帶大家一起來(lái)看看吧。
創(chuàng)新互聯(lián)公司堅(jiān)持“要么做到,要么別承諾”的工作理念,服務(wù)領(lǐng)域包括:網(wǎng)站制作、成都做網(wǎng)站、企業(yè)官網(wǎng)、英文網(wǎng)站、手機(jī)端網(wǎng)站、網(wǎng)站推廣等服務(wù),滿足客戶于互聯(lián)網(wǎng)時(shí)代的宜川網(wǎng)站設(shè)計(jì)、移動(dòng)媒體設(shè)計(jì)的需求,幫助企業(yè)找到有效的互聯(lián)網(wǎng)解決方案。努力成為您成熟可靠的網(wǎng)絡(luò)建設(shè)合作伙伴!
寫(xiě)一個(gè)Shiro的過(guò)濾器
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請(qǐng)求處理 用于前后臺(tái)分離的場(chǎng)景 */ public class AjaxFilter extends AdviceFilter { @Override protected boolean preHandle(ServletRequest request, ServletResponse response) throws Exception { // 先判斷是不是ajax請(qǐng)求 ajax請(qǐng)求都會(huì)自帶一個(gè)請(qǐng)求頭X-Requested-With // 如果有值而且是XMLHttpRequest那就可以確定是個(gè)ajax請(qǐng)求 返回json數(shù)據(jù)就行 HttpServletRequest req = (HttpServletRequest) request; if ("XMLHttpRequest".equals(req.getHeader("X-Requested-With"))) { // 獲取到當(dāng)前的登錄對(duì)象 如果是沒(méi)有經(jīng)過(guò)認(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是我寫(xiě)的一個(gè)包裝類,用來(lái)向前臺(tái)返回?cái)?shù)據(jù) resp.getWriter().write(JSON.toJSONString(Message.failed("請(qǐng)登錄后操作"))); return false; } else { // 經(jīng)過(guò)認(rèn)證的話就放過(guò)去 讓下一個(gè)過(guò)濾器處理 return true; } } else { // 不是ajax請(qǐng)求的話也放過(guò)去 讓下一個(gè)過(guò)濾器處理 return true; } } }
Shiro的配置類里面的配置我就全部放出來(lái)了 就看一下與這次配置相關(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)證頁(yè)面的URL factoryBean.setUnauthorizedUrl(unauthorizedUrl); // 這里是設(shè)置過(guò)濾器 // 要注意 如果你沒(méi)寫(xiě)的話默認(rèn)是有一個(gè)FormAuthenticationFilter // 如果你手動(dòng)設(shè)置了過(guò)濾器會(huì)覆蓋掉默認(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)頁(yè)請(qǐng)求都能正常處理了
以上就是關(guān)于用代碼解析SpringBoot基于Shiro處理ajax請(qǐng)求的內(nèi)容,如果你們有學(xué)習(xí)到知識(shí)或者技能,可以把它分享出去讓更多的人看到。
名稱欄目:用代碼解析SpringBoot基于Shiro處理ajax請(qǐng)求
文章URL:http://jinyejixie.com/article32/gdpgpc.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供域名注冊(cè)、全網(wǎng)營(yíng)銷推廣、、手機(jī)網(wǎng)站建設(shè)、自適應(yīng)網(wǎng)站、網(wǎng)頁(yè)設(shè)計(jì)公司
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)