java自定义密码或用户名错误异常,自定义 UsernamePasswordToken 报错 java.lang.ClassCastException: org.apache.shiro.authc...

UsernamePasswordToken 转型时 出现了异常

代码如下

7bcde1af5249a8d8e963fef11fc169fc.png

没有地方使用我们的自己扩展的CustomerUsernamePasswordToken类,只是转型而已,并没有去实例化它,这才是引起问题的根源,问题发现了要如何解决它呢?我们在配置的使用并并未制定表单过滤器,此时默认使用的是FormAuthenticationFilter,而Token默认使用的也是UsernamePasswordToken,由此看来,我们扩展的CustomerUsernamePasswordToken就成了摆设,此时就要想办法如何将我们的扩展引用到程序里去呢?

既然默认的是UsernamePasswordToken,那么是如何将UsernamePasswordToken注入的呢?我们进入默认的Filter(FormAuthenticationFilter)可以看到createToken,这个是创建Token的,那么似乎可以和我们的Token搭上边了,我们需要自定义一个拦截器让它继承FormAuthenticationFilter ,重写 createToken 方法就行了

5e3e8fc15426199ad7c46ff676179c14.png

扩展完成后,需要配置默认的过滤器为我们的扩展,shiro的配置如下:

6b4c60633d6dd66fe636c3786d434e79.png

这样就完成啦

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值