Spring security认证与授权(四)

在第三个实例基础上我做了第四个实例,这个实例很简单。默认情况下,角色名称必须以ROLE_开头,否则spring security框架无法识别,有时这会让人觉得很不爽。当然,这是可以改变的。

第四个实例:

这里只需要在第三个实例上修改applicationContext-security.xml:

<?xml version="1.0"encoding="UTF-8"?>

<beans xmlns="http://www.springframework.org/schema/beans"

    xmlns:sec="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-2.5.xsd

   http://www.springframework.org/schema/security

   http://www.springframework.org/schema/security/spring-security-2.0.4.xsd">

    <!-- 自动配置模式,拦截所有请求,有ROLE_USER才可以通过 -->

    <sec:http auto-config="true"access-decision-manager-ref="accessDecisionManager">

        <sec:intercept-url pattern="/login.jsp"  filters="none"/>

        <!-- 增加ROLE_ADMIN角色-->

        <sec:intercept-url pattern="/admin.jsp" access="AUTH_ADMIN"/>

        <sec:intercept-url pattern="/**" access="AUTH_USER"/>

        <sec:form-login login-page="/login.jsp" authentication-failure-url="/login.jsp?login_error=1"/> 

 

    </sec:http>

     <sec:authentication-provider>

            <sec:user-service>

                                <!-- 添加ROLE_ADMIN角色 -->

                <sec:user name="admin" password="admin"authorities="AUTH_USER,AUTH_ADMIN"/>

                <sec:user name="sharp" password="sharp"authorities="AUTH_USER"/>

            </sec:user-service>

    </sec:authentication-provider>

    <!-- 认证管理器。用户名密码都集成在配置文件中 -->

    <sec:authentication-manager alias="authenticationManager"/>

    <bean id="accessDecisionManager" class="org.springframework.security.vote.AffirmativeBased">

       <property name="decisionVoters">

           <list>

              <bean class="org.springframework.security.vote.RoleVoter">

                  <property name="rolePrefix" value="AUTH_"/>

              </bean>

           </list>

       </property>

        </bean>

   

     <!-- 指定中文资源,不是必须的。如果没有这个bean,则有关springSecurity的提示会是英文     -->

     <bean id="messageSource"

       class="org.springframework.context.support.ReloadableResourceBundleMessageSource">

        <property name="basename"  value="classpath:org/springframework/security/messages_zh_CN"/> 

     </bean>

 

</beans>

就是这一行

<property name="rolePrefix" value="AUTH_"/>

你可以将前缀修改为自己想要的。

不知不觉说了四个实例,不过,这些实例真的是太简单了,而且没什么实际意义,但是,对于开始接触Spring Security的童鞋还是很有帮助的。

在实际的应用中,我们都会将Spring Security与数据库结合。接下来,我们引入数据库继续学习Spring security。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值