Spring security学习笔记-1

主动辞职浪了两个月,最终在爸妈每天催着下,随便找了家公司上班去了,新公司里面用到了spring security框架,以前用的shiro还没用上,就换了这个。。。总之先记录一下,之后说不定用的上web

首先添加maven依赖:(里面有好多依赖,应该是包括配置库,核心库,标签库,认证库,我没看懂,暂时先记录一下,之后进行修改)正则表达式

<dependency>
   <groupId>org.springframework.security</groupId>
   <artifactId>spring-security-config</artifactId>
   <version>${spring.security.version}</version>
</dependency>
<dependency>
   <groupId>org.springframework.security</groupId>
   <artifactId>spring-security-core</artifactId>
   <version>${spring.security.version}</version>
</dependency>
<dependency>
   <groupId>org.springframework.security</groupId>
   <artifactId>spring-security-taglibs</artifactId>
   <version>${spring.security.version}</version>
</dependency>
<dependency>
   <groupId>org.springframework.security</groupId>
   <artifactId>spring-security-web</artifactId>
   <version>${spring.security.version}</version>
</dependency>
<dependency>
   <groupId>org.springframework.security.oauth</groupId>
   <artifactId>spring-security-oauth2</artifactId>
   <version>2.1.0.RELEASE</version>
</dependency>

而后添加配置文件:application-security.xmlspring

1.引入命名空间(其中security是自定义名称)数据库

<beans xmlns="http://www.springframework.org/schema/beans"
  xmlns:security="http://www.springframework.org/schema/security"
  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-3.1.xsd
          http://www.springframework.org/schema/security
          http://www.springframework.org/schema/security/spring-security-3.1.xsd">

</beans>

2.定义HTTP元素app

<security:http auto-config="true">
      <security:intercept-url pattern="/**" access="ROLE_USER"/>
</security:http>

 其中auto-config=“true”会默认生成一个登录页面,如上定义中,intercept-url 定义了一个权限控制的规则。pattern 属性表示咱们将对哪些 url 进行权限控制,其也能够是一个正则表达式,如上的写法表示咱们将对全部的 URL 进行权限控制;access 属性表示在请求对应的 URL 时须要什么权限,默认配置时它应该是一个以逗号分隔的角色列表,请求的用户只需拥有其中的一个角色就能成功访问对应的 URL。这里的 “ROLE_USER” 表示请求的用户应当具备 ROLEUSER 角色。“ROLE” 前缀是一个提示 Spring 使用基于角色的检查的标记。框架

3.定义AuthenticationManage用于认证maven

<security:authentication-manager>
      <security:authentication-provider>
         <security:user-service>
            <security:user name="user" password="user" authorities="ROLE_USER"/>
            <security:user name="admin" password="admin" authorities="ROLE_USER, ROLE_ADMIN"/>
         </security:user-service>
      </security:authentication-provider>
   </security:authentication-manager>

 authentication-manager 元素指定了一个 AuthenticationManager,其须要一个 AuthenticationProvider(对应 authentication-provider 元素)来进行真正的认证,默认状况下 authentication-provider 对应一个 DaoAuthenticationProvider,其须要 UserDetailsService(对应 user-service 元素)来获取用户信息 UserDetails(对应 user 元素)。这里咱们只是简单的使用 user 元素来定义用户,而实际应用中这些信息一般都是须要从数据库等地方获取的,这个将放到后续再讲。咱们能够看到经过 user 元素咱们能够指定 user 对应的用户名、密码和拥有的权限。user-service 还支持经过 properties 文件来指定用户信息,如:ide

<security:user-service properties="/WEB-INF/config/users.properties"/>

其中属性文件应遵循以下格式:url

username=password,grantedAuthority[,grantedAuthority][,enabled|disabled]

 因此,对应上面的配置文件,咱们的 users.properties 文件的内容应该以下所示:code

#username=password,grantedAuthority[,grantedAuthority][,enabled|disabled]
user=user,ROLE_USER
admin=admin,ROLE_USER,ROLE_ADMIN

 至此,咱们的 Spring Security 配置文件的配置就完成了。完整配置文件将以下所示。

<beans xmlns="http://www.springframework.org/schema/beans"
  xmlns:security="http://www.springframework.org/schema/security"
  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-3.1.xsd
          http://www.springframework.org/schema/security
          http://www.springframework.org/schema/security/spring-security-3.1.xsd">

   <security:http auto-config="true">
      <security:intercept-url pattern="/**" access="ROLE_USER"/>
   </security:http>    

   <security:authentication-manager>
      <security:authentication-provider>
         <security:user-service>
            <security:user name="user" password="user" authorities="ROLE_USER"/>
            <security:user name="admin" password="admin" authorities="ROLE_USER, ROLE_ADMIN"/>
         </security:user-service>
      </security:authentication-provider>
   </security:authentication-manager>

</beans>

最后配置文件到spring的配置文件里面或者web.xml里面就能够了 

先这样子吧,之后了解了继续修改

相关文章
相关标签/搜索