SpringSecurity hideUserNotFoundExceptions

项目中,使用SpringSecurity用户登录验证时,密码错误能够正常抛出异常,
但是用户不存在的情况却依然抛出密码错误的异常。

异常:总是抛出UsernameNotFoundException异常,打印出Badcredentials。

原因:hideUserNotFoundExceptions属性默认为ture,会隐藏用户不存在的异常

查看AbstractUserDetailsAuthenticationProvider的authenticate()方法
发现问题所在:hideUserNotFoundExceptions属性默认为ture
这里写图片描述

解决方案:
修改配置文件如下

<sec:authentication-manager alias="authenticationManager">
        <sec:authentication-provider ref="daoAuthenticationProvider"> 

             <!-- <sec:password-encoder ref="passwordEncoder">

                <salt-source ref="saltSource"/>

             </sec:password-encoder> -->

        </sec:authentication-provider>

    </sec:authentication-manager>

    <!-- 加了这段才可以捕捉UsernameNotFoundException -->
    <bean id="daoAuthenticationProvider"     class="org.springframework.security.authentication.dao.DaoAuthenticationProvider">  
      <!-- 必须实现的接口 --> 
      <property name="userDetailsService" ref="hibernateUserDetailsManager" />  
      <!-- 是否隐藏用户没有找到的异常,默认为true,即将不能准确地报告用户是否存在的异常 -->  
      <property name="hideUserNotFoundExceptions" value="false"/>

   </bean>
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值