教育行業(yè)A股IPO第一股(股票代碼 003032)

全國(guó)咨詢/投訴熱線:400-618-4000

Spring Security初體驗(yàn)

更新時(shí)間:2018年09月21日17時(shí)15分 來(lái)源:傳智播客 瀏覽次數(shù):

Spring Security是一個(gè)能夠?yàn)榛?/font>Spring的企業(yè)應(yīng)用系統(tǒng)提供聲明式的安全訪問(wèn)控制解決方案的安全框架 
要想使用他我先的加依賴


<dependency>
    <groupId>org.springframework.security</groupId>
    <artifactId>spring-security-core</artifactId>
    <version>
5.0.1.RELEASE</version>
</dependency>
要做權(quán)限管理哪必須要攔截用戶的請(qǐng)求,那么當(dāng)然就有攔截器,那么就要在web.xml里面配置


<!--springSecurity委派過(guò)濾器-->
<filter>
    <filter-name>springSecurityFilterChain</filter-name>
    <filter-class>org.springframework.web.filter.DelegatingFilterProxy</filter-class>
</filter>
<filter-mapping>
    <filter-name>springSecurityFilterChain</filter-name>
    <url-pattern>/*</url-pattern>
</filter-mapping>
這樣所有的請(qǐng)求都要通過(guò)
security的檢測(cè)
哪他是怎樣做權(quán)限管理的呢下面來(lái)看下  
security 的配置文件
springSecurity.xml
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
       xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
       xmlns:security="http://www.springframework.org/schema/security"
       xsi:schemaLocation="http://www.springframework.org/schema/beanshttp://www.springframework.org/schema/beans/spring-beans.xsdhttp://www.springframework.org/schema/security http://www.springframework.org/s ... spring-security.xsd">
    <!--放行一些資源-->
    <security:http pattern="/login.jsp" security="none"></security:http>
    <security:http pattern="/failer.jsp" security="none"></security:http>
    <security:http pattern="/css/**" security="none"></security:http>
    <security:http pattern="/img/**" security="none"></security:http>
    <security:http pattern="/plugins/**" security="none"></security:http>


    <security:http auto-config="true" use-expressions="false">
        <security:intercept-url pattern="/**" access="ROLE_USER"></security:intercept-url>
        <!--配置登陸表單-->
        <security:form-login
                login-page="/login.jsp"
                login-processing-url="/login"
                default-target-url="/index.jsp"
                authentication-failure-url="/failer.jsp"
                username-parameter="username"
                password-parameter="password"
        ></security:form-login>

        <!--退出配置-->
        <security:logout
                invalidate-session="true"
                logout-url="/logout"
                logout-success-url="/login.jsp" ></security:logout>
        <!--關(guān)閉跨域請(qǐng)求-->
        <security:csrf disabled="true"></security:csrf>
    </security:http>

    <!--登陸認(rèn)證連接數(shù)據(jù)庫(kù),執(zhí)行service方法-->
    <security:authentication-manager>
        <!--引用容器中的UserService對(duì)象,此對(duì)象一定要實(shí)現(xiàn)接口UserDetailsService-->
        <security:authentication-provider user-service-ref="userServiceImpl"></security:authentication-provider>
    </security:authentication-manager>
</beans> 
從下面這行代碼可以看出他是基于URL 來(lái)控制的  
<security:intercept-url pattern="/**" access="ROLE_USER"></security:intercept-url>




猜你喜歡:
冒泡排序算法[動(dòng)圖介紹]
什么是java變量,java變量的定義
Java中switch條件語(yǔ)句的用法
0 分享到:
和我們?cè)诰€交談!