spring security的配置文件原来也需要顺序

spring security原来也是有顺序的啊

<?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-2.5.xsd
                        http://www.springframework.org/schema/security http://www.springframework.org/schema/security/spring-security-2.0.1.xsd">
 

    <http auto-config="true"/>

    <authentication-provider>
        <jdbc-user-service data-source-ref="dataSource"
            users-by-username-query="select username,password,status as enabled
                                       from user
                                      where username=?"
            authorities-by-username-query="select u.username,r.name as authority
                                             from user u
                                             join user_role ur
                                               on u.id=ur.user_id
                                             join role r
                                               on r.id=ur.role_id
                                            where u.username=?"/>
    </authentication-provider>

    <global-method-security/>
  
     <beans:bean id="messageService" class="a.MessageServiceImpl"/>
    <beans:bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource">
        <beans:property name="driverClassName" value="com.mysql.jdbc.Driver"/>
        <beans:property name="url" value="jdbc:mysql://localhost:3306/tests"/>
        <beans:property name="username" value="root"/>
        <beans:property name="password" value="root"/>
        </beans:bean>
    <beans:bean id="resourceDetailsMonitor" class="a.ResourceDetailsMonitor">
        <beans:property name="dataSource" ref="dataSource" />
        <beans:property name="filterSecurityInterceptor" ref="_filterSecurityInterceptor" />
        <beans:property name="delegatingMethodDefinitionSource" ref="_delegatingMethodDefinitionSource" />
    </beans:bean>
 
  
</beans:beans>

这是我刚开始的配置但是打开页面后应该受保护的方法根本不受保护

但是将<beans:bean id="messageService" class="a.MessageServiceImpl"/>
换到resourceDetailsMonitor后居然页面管用了正确的配置如下

<?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-2.5.xsd
                        http://www.springframework.org/schema/security http://www.springframework.org/schema/security/spring-security-2.0.1.xsd">
 

    <http auto-config="true"/>

    <authentication-provider>
        <jdbc-user-service data-source-ref="dataSource"
            users-by-username-query="select username,password,status as enabled
                                       from user
                                      where username=?"
            authorities-by-username-query="select u.username,r.name as authority
                                             from user u
                                             join user_role ur
                                               on u.id=ur.user_id
                                             join role r
                                               on r.id=ur.role_id
                                            where u.username=?"/>
    </authentication-provider>

    <global-method-security/>
  
   
    <beans:bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource">
        <beans:property name="driverClassName" value="com.mysql.jdbc.Driver"/>
        <beans:property name="url" value="jdbc:mysql://localhost:3306/tests"/>
        <beans:property name="username" value="root"/>
        <beans:property name="password" value="root"/>
        </beans:bean>
    <beans:bean id="resourceDetailsMonitor" class="a.ResourceDetailsMonitor">
        <beans:property name="dataSource" ref="dataSource" />
        <beans:property name="filterSecurityInterceptor" ref="_filterSecurityInterceptor" />
        <beans:property name="delegatingMethodDefinitionSource" ref="_delegatingMethodDefinitionSource" />
    </beans:bean>
 
    <beans:bean id="messageService" class="a.MessageServiceImpl"/>
</beans:beans>

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值