溫馨提示×

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

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

spring boot集成shiro的示例分析

發(fā)布時(shí)間:2021-07-08 14:03:08 來(lái)源:億速云 閱讀:111 作者:小新 欄目:編程語(yǔ)言

小編給大家分享一下spring boot集成shiro的示例分析,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

spring boot提供了一個(gè)自帶的認(rèn)證框架,同時(shí)也提供自定義的javaconfig配置擴(kuò)展,spring-sercurity同樣也是優(yōu)秀的框架,但是習(xí)慣了用apache shiro框架,而且原項(xiàng)目就是集成的shiro框架,到網(wǎng)上找了一下配置方式,沒(méi)找到完全配置的方法,因此決定自己動(dòng)手,豐衣足食!

        要在spring boot上集成其他框架,首先要會(huì)spring javaconfig方法,利用此方法同樣可以配置其他模塊。

        開(kāi)始前需要導(dǎo)入maven依賴(shiro-web可選):         

  <dependency> 
  <groupId>org.apache.shiro</groupId> 
  <artifactId>shiro-core</artifactId> 
  <version>${shiro.version}</version> 
</dependency> 
<dependency> 
  <groupId>org.apache.shiro</groupId> 
  <artifactId>shiro-web</artifactId> 
  <version>${shiro.version}</version> 
</dependency> 
<dependency> 
  <groupId>org.apache.shiro</groupId> 
  <artifactId>shiro-spring</artifactId> 
  <version>${shiro.version}</version> 
</dependency> 
<dependency> 
  <groupId>org.apache.shiro</groupId> 
  <artifactId>shiro-ehcache</artifactId> 
  <version>${shiro.version}</version> 
</dependency>

        原shiro集成spring的配置拿出來(lái),如下:

<?xml version="1.0" encoding="UTF-8"?> 
<beans xmlns="http://www.springframework.org/schema/beans" 
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" 
xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd" 
default-lazy-init="true"> 
<description>Shiro安全配置 來(lái)源于: http://shiro.apache.org/spring.html 
</description> 
<bean id="securityManager" class="org.apache.shiro.web.mgt.DefaultWebSecurityManager"> 
<!-- Single realm app. If you have multiple realms, use the 'realms' property 
instead. --> 
<property name="realm" ref="ShiroRealmImpl" /> 
<property name="cacheManager" ref="shiroEhcacheManager" /> 
</bean> 
<!-- Define the realm you want to use to connect to your back-end security 
datasource: --> 
<bean id="ShiroRealmImpl" class="com.wechatserver.web.services.system.impl.ShiroRealmImpl" /> 
<bean id="shiroFilter" class="org.apache.shiro.spring.web.ShiroFilterFactoryBean"> 
<property name="securityManager" ref="securityManager" /> 
<property name="loginUrl" value="/login" /> <!-- 沒(méi)有權(quán)限或者失敗后跳轉(zhuǎn)的頁(yè)面 --> 
<property name="successUrl" value="/sa/index" /> 
<property name="filterChainDefinitions"> 
<!-- , roles[admin], perms[document:read] --> 
<value> 
<!-- 
/user/** = authc 
/role/edit/* = perms[role:edit] 
/role/save = perms [role:edit] 
/role/list = perms [role:view] 
--> 
/sa/** = authc 
/** = anon 
</value> 
</property> 
</bean> 
<!-- 用戶授權(quán)/認(rèn)證信息Cache, 采用EhCache 緩存 --> 
<bean id="shiroEhcacheManager" class="org.apache.shiro.cache.ehcache.EhCacheManager"> 
<property name="cacheManagerConfigFile" value="classpath:ehcache-shiro.xml" /> 
</bean> 
<!-- 保證實(shí)現(xiàn)了Shiro內(nèi)部lifecycle函數(shù)的bean執(zhí)行 --> 
<bean id="lifecycleBeanPostProcessor" class="org.apache.shiro.spring.LifecycleBeanPostProcessor" /> 
<!-- AOP式方法級(jí)權(quán)限檢查 --> 
<!-- Enable Shiro Annotations for Spring-configured beans. Only run after --> 
<!-- the lifecycleBeanProcessor has run: --> 
<bean 
class="org.springframework.aop.framework.autoproxy.DefaultAdvisorAutoProxyCreator" 
depends-on="lifecycleBeanPostProcessor"> 
<property name="proxyTargetClass" value="true" /> 
</bean> 
<bean 
class="org.apache.shiro.spring.security.interceptor.AuthorizationAttributeSourceAdvisor"> 
<property name="securityManager" ref="securityManager" /> 
</bean> 
</beans>

好多類啊,沒(méi)辦法一個(gè)一個(gè)配置,javaconfig文件如下:

import java.util.LinkedHashMap; 
import java.util.Map; 
import org.apache.shiro.cache.ehcache.EhCacheManager; 
import org.apache.shiro.spring.LifecycleBeanPostProcessor; 
import org.apache.shiro.spring.security.interceptor.AuthorizationAttributeSourceAdvisor; 
import org.apache.shiro.spring.web.ShiroFilterFactoryBean; 
import org.apache.shiro.web.mgt.DefaultWebSecurityManager; 
import org.springframework.aop.framework.autoproxy.DefaultAdvisorAutoProxyCreator; 
import org.springframework.context.annotation.Bean; 
import org.springframework.context.annotation.Configuration; 
@Configuration 
public class ShiroConfiguration { 
  private static Map<String, String> filterChainDefinitionMap = new LinkedHashMap<String, String>(); 
  @Bean(name = "ShiroRealmImpl") 
  public ShiroRealmImpl getShiroRealm() { 
    return new ShiroRealmImpl(); 
  } 
  @Bean(name = "shiroEhcacheManager") 
  public EhCacheManager getEhCacheManager() { 
    EhCacheManager em = new EhCacheManager(); 
    em.setCacheManagerConfigFile("classpath:ehcache-shiro.xml"); 
    return em; 
  } 
  @Bean(name = "lifecycleBeanPostProcessor") 
  public LifecycleBeanPostProcessor getLifecycleBeanPostProcessor() { 
    return new LifecycleBeanPostProcessor(); 
  } 
  @Bean 
  public DefaultAdvisorAutoProxyCreator getDefaultAdvisorAutoProxyCreator() { 
    DefaultAdvisorAutoProxyCreator daap = new DefaultAdvisorAutoProxyCreator(); 
    daap.setProxyTargetClass(true); 
    return daap; 
  } 
  @Bean(name = "securityManager") 
  public DefaultWebSecurityManager getDefaultWebSecurityManager() { 
    DefaultWebSecurityManager dwsm = new DefaultWebSecurityManager(); 
    dwsm.setRealm(getShiroRealm()); 
    dwsm.setCacheManager(getEhCacheManager()); 
    return dwsm; 
  } 
  @Bean 
  public AuthorizationAttributeSourceAdvisor getAuthorizationAttributeSourceAdvisor() { 
    AuthorizationAttributeSourceAdvisor aasa = new AuthorizationAttributeSourceAdvisor(); 
    aasa.setSecurityManager(getDefaultWebSecurityManager()); 
    return new AuthorizationAttributeSourceAdvisor(); 
  } 
  @Bean(name = "shiroFilter") 
  public ShiroFilterFactoryBean getShiroFilterFactoryBean() { 
    ShiroFilterFactoryBean shiroFilterFactoryBean = new ShiroFilterFactoryBean(); 
    shiroFilterFactoryBean 
        .setSecurityManager(getDefaultWebSecurityManager()); 
    shiroFilterFactoryBean.setLoginUrl("/login"); 
    shiroFilterFactoryBean.setSuccessUrl("/sa/index"); 
    filterChainDefinitionMap.put("/sa/**", "authc"); 
    filterChainDefinitionMap.put("/**", "anon"); 
    shiroFilterFactoryBean 
        .setFilterChainDefinitionMap(filterChainDefinitionMap); 
    return shiroFilterFactoryBean; 
  } 
}

注意點(diǎn):最后一個(gè)是filterChainDefinitionMap的初始化,Map用的是LinkedHashMap來(lái)初始化的,各位應(yīng)用的時(shí)候?qū)⑵渑渲贸蓀roperties文件,然后初始化就ok了,改寫(xiě)好后直接啟動(dòng)Ok,搬運(yùn)到spring boot應(yīng)該是OK的。

別忘了在ehcache-shiro.xml

<ehcache updateCheck="false" name="shiroCache"> 
  <defaultCache 
      maxElementsInMemory="10000" 
      eternal="false" 
      timeToIdleSeconds="120" 
      timeToLiveSeconds="120" 
      overflowToDisk="false" 
      diskPersistent="false" 
      diskExpiryThreadIntervalSeconds="120" 
      /> 
</ehcache>

以上是“spring boot集成shiro的示例分析”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對(duì)大家有所幫助,如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注億速云行業(yè)資訊頻道!

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI