亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

用代碼解析SpringBoot基于Shiro處理ajax請求

發布時間:2020-07-18 09:55:27 來源:億速云 閱讀:195 作者:小豬 欄目:編程語言

這篇文章主要為大家展示了用代碼解析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和網頁請求都能正常處理了

以上就是關于用代碼解析SpringBoot基于Shiro處理ajax請求的內容,如果你們有學習到知識或者技能,可以把它分享出去讓更多的人看到。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

九龙县| 周宁县| 谷城县| 通渭县| 藁城市| 乌鲁木齐县| 夏津县| 普兰店市| 固阳县| 靖西县| 柳林县| 罗江县| 江阴市| 南丹县| 大埔区| 二连浩特市| 阳山县| 新龙县| 阿瓦提县| 长春市| 江西省| 怀远县| 丰城市| 巢湖市| 天门市| 邹城市| 澄迈县| 攀枝花市| 富顺县| 含山县| 皮山县| 张掖市| 博爱县| 盘锦市| 双桥区| 天台县| 皋兰县| 崇州市| 历史| 江都市| 九龙城区|