Spring Security访问控制详解编程语言

Spring Security简介

Spring Security是一个能够为基于Spring的企业应用系统提供声明式的安全访问控制解决方案的安全框架。它提供了一组可以在Spring应用上下文中配置的Bean,充分利用了Spring IoC,DI(控制反转Inversion of Control ,DI:Dependency Injection 依赖注入)和AOP(面向切面编程)功能,为应用系统提供声明式的安全访问控制功能,减少了为企业系统安全控制编写大量重复代码的工作。
Spring Security安全框架:授权(角色)和认证(登录)。


Spring Security入门小程序

第一步:创建apache maven webapp工程,编写pom.xml

<?xml version="1.0" encoding="UTF-8"?> 
 
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" 
         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0_0.xsd"> 
    <modelVersion>4.0.0</modelVersion> 
    <groupId>cn.itcast.demo</groupId> 
    <artifactId>spring-security-demo</artifactId> 
    <packaging>war</packaging> 
    <version>1.0-SNAPSHOT</version> 
    <properties> 
        <spring.version>4.3.10.RELEASE</spring.version> 
    </properties> 
    <dependencies> 
        <dependency> 
            <groupId>org.springframework</groupId> 
            <artifactId>spring-core</artifactId> 
            <version>${spring.version}</version> 
        </dependency> 
        <dependency> 
            <groupId>org.springframework</groupId> 
            <artifactId>spring-web</artifactId> 
            <version>${spring.version}</version> 
        </dependency> 
        <dependency> 
            <groupId>org.springframework</groupId> 
            <artifactId>spring-webmvc</artifactId> 
            <version>${spring.version}</version> 
        </dependency> 
        <dependency> 
            <groupId>org.springframework</groupId> 
            <artifactId>spring-context-support</artifactId> 
            <version>${spring.version}</version> 
        </dependency> 
        <dependency> 
            <groupId>org.springframework</groupId> 
            <artifactId>spring-test</artifactId> 
            <version>${spring.version}</version> 
        </dependency> 
        <dependency> 
            <groupId>org.springframework</groupId> 
            <artifactId>spring-jdbc</artifactId> 
            <version>${spring.version}</version> 
        </dependency> 
        <dependency> 
            <groupId>org.springframework.security</groupId> 
            <artifactId>spring-security-web</artifactId> 
            <version>4.1.0.RELEASE</version> 
        </dependency> 
        <dependency> 
            <groupId>org.springframework.security</groupId> 
            <artifactId>spring-security-config</artifactId> 
            <version>4.1.0.RELEASE</version> 
        </dependency> 
        <dependency> 
            <groupId>javax.servlet</groupId> 
            <artifactId>servlet-api</artifactId> 
            <version>2.5</version> 
            <scope>provided</scope> 
        </dependency> 
    </dependencies> 
    <build> 
        <plugins> 
            <!-- java编译插件 --> 
            <plugin> 
                <groupId>org.apache.maven.plugins</groupId> 
                <artifactId>maven-compiler-plugin</artifactId> 
                <version>3.2</version> 
                <configuration> 
                    <source>1.8</source> 
                    <target>1.8</target> 
                    <encoding>UTF-8</encoding> 
                </configuration> 
            </plugin> 
            <plugin> 
                <groupId>org.apache.tomcat.maven</groupId> 
                <artifactId>tomcat7-maven-plugin</artifactId> 
                <configuration> 
                    <!-- 指定端口 --> 
                    <port>9090</port> 
                    <!-- 请求路径 --> 
                    <path>/</path> 
                </configuration> 
            </plugin> 
        </plugins> 
    </build> 
</project>

第二步:编写web.xml

<?xml version="1.0" encoding="UTF-8"?> 
<web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" 
         xmlns="http://java.sun.com/xml/ns/javaee" 
         xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd" 
         version="2.5"> 
    <context-param> 
        <param-name>contextConfigLocation</param-name> 
        <param-value>classpath:spring/spring-security.xml</param-value> 
    </context-param> 
    <listener> 
        <listener-class> 
            org.springframework.web.context.ContextLoaderListener 
        </listener-class> 
    </listener> 
    <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> 
</web-app>

第三步:创建spring-security.xml

<?xml version="1.0" encoding="UTF-8"?> 
<beans:beans xmlns="http://www.springframework.org/schema/security" 
             xmlns:beans="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 
        http://www.springframework.org/schema/security http://www.springframework.org/schema/security/spring-security.xsd"> 
 
    <!-- 页面拦截规则 --> 
    <http use-expressions="false"> 
        <intercept-url pattern="/**" access="ROLE_USER"/> 
        <form-login/> 
    </http> 
 
    <!-- 认证管理器 --> 
    <authentication-manager> 
        <authentication-provider> 
            <user-service> 
                <user name="admin" password="admin" authorities="ROLE_USER"/> 
            </user-service> 
        </authentication-provider> 
    </authentication-manager> 
</beans:beans>

配置说明:
intercept-url表示拦截页面
/* 表示的是该目录下的资源,只包括本级目录不包括下级目录;
/** 表示的是该目录以及该目录下所有级别子目录的资源。

form-login为开启表单登陆

以上步骤完成后,工程目录结构如下:
工程目录结构

第四步:配置好maven的tomcat插件及命令:
maven tomcat

第五步:访问IT虾米网,会被spring security的认证管理器ROLE_USER拦截,跳转到spring security自带的登录页面:
spring security login
此时,输入认证管理器中配置好的用户名和密码,才能跳转到index.jsp页面。

用户自定义登录页

实际开发中,我们不可能使用系统生成的登录页,而是使用我们自己的登录页。
第六步:构建自定义的登录页面login.html

<!DOCTYPE html> 
<html lang="en"> 
<head> 
    <meta charset="UTF-8"> 
    <title>登录页面</title> 
</head> 
<body> 
<form action='/login' method='POST'> 
    <table> 
        <tr> 
            <td>用户名:</td> 
            <td><input type='text' name='username' value=''></td> 
        </tr> 
        <tr> 
            <td>密码:</td> 
            <td><input type='password' name='password'/></td> 
        </tr> 
        <tr> 
            <td colspan='2'><input name="submit" type="submit" value="登陆"/></td> 
        </tr> 
    </table> 
</form> 
</body> 
</html>

第七步:构建登录失败页面login_error.html

<!DOCTYPE html> 
<html lang="en"> 
<head> 
    <meta charset="UTF-8"> 
    <title>登录失败页面</title> 
</head> 
<body> 
    <h1 style="color: red">用户名或密码错误,请重新返回登录页面输入。</h1> 
</body> 
</html>

第八步:重新配置spring-security.xml中的http元素。

    <!-- 以下页面不被拦截 --> 
    <http pattern="/login.html" security="none"></http> 
    <http pattern="/login_error.html" security="none"></http> 
    <!-- 页面拦截规则 --> 
    <http use-expressions="false"> 
        <intercept-url pattern="/**" access="ROLE_USER"/> 
        <form-login login-page="/login.html" default-target-url="/index.html" 
                    authentication-failure-url="/login_error.html"/> 
        <csrf disabled="true"/> 
    </http> 

第九步:再执行第五步,跳转到访问自定义的登录页面:
自定义 login.html
登录成功,跳转至index.jsp:
index.jsp
登录失败,跳转至login_error.html:
login_error.html

配置说明:
security=”none”设置此资源不被拦截.
如果你没有设置登录页security=”none”,将会出现以下错误:
这里写图片描述
因为登录页会被反复重定向。

login-page:指定登录页面。
authentication-failure-url:指定了身份验证失败时跳转到的页面。
default-target-url:指定了成功进行身份验证和授权后默认呈现给用户的页面。

csrf disabled=”true”关闭csrf ,如果不加会出现错误:
这里写图片描述
CSRF(Cross-site request forgery)跨站请求伪造,也被称为“One Click Attack”或者Session Riding,通常缩写为CSRF或者XSRF,是一种对网站的恶意利用。

原创文章,作者:ItWorker,如若转载,请注明出处:https://blog.ytso.com/tech/pnotes/19604.html

(0)
上一篇 2021年7月19日 22:18
下一篇 2021年7月19日 22:18

相关推荐

发表回复

登录后才能评论