spring-security_自定义加密器

虽然 spring security 已经提供了比较完善的加密机制,但是有时根据业务需求需要定制自己的加密方式。
spring security 提供了加密扩充的接口,下文主要介绍如何在 spring security 中添加自定义的加密器。

配置 spring security 开发环境

项目目录如下:

工程目录结构

自定义加密器

实现接口 PasswordEncoder

public class MPasswordEncoder implements PasswordEncoder {

    /**
     * 对密码进行加密并返回
     */
    public String encode(CharSequence rawPassword) {

        String encPassword = rawPassword.toString();
        return encPassword;
    }

    /**
     * 验证密码是否正确
     */
    public boolean matches(CharSequence rawPassword, String encodedPassword) {

        return encode(rawPassword).equals(encodedPassword);
    }
}

注意:

  • encode(rawPassword)方法用来进行加密,其参数rawPassword 表示从表单提交上来的密码。
  • mathes(rawPassword,encodedPassword) 方法进行密码匹配,其参数rawPassword 表示从表单提交上来的密码,在比较密码之前应该调用encode()方法对rawPassword进行加密;参数encodedPassword表示从数据库或者其他方式获取到的服务器上存储的密码,用来和用户提交上来的密码进行比较。

修改 security 配置文件

修改 security.xml 文件,加载并引用自定义的加密器。

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

    <authentication-manager alias="authenticationManager">
        <authentication-provider>
            <!-- 2、引用自定义加密器 -->
            <password-encoder ref="mPasswordEncoder" />

            <user-service>
                <user name="admin" password="password"
                    authorities="ROLE_USER" />
            </user-service>
        </authentication-provider>
    </authentication-manager>
    
    <!-- 1、加载自定义加密器 -->
    <b:bean id="mPasswordEncoder" class="com.sfq.MPasswordEncoder"></b:bean>
</b:beans>

其中:

  • <b:bean id="mPasswordEncoder" class="com.sfq.MPasswordEncoder"></b:bean> 表示加载自定义的加密器。
  • <password-encoder ref="mPasswordEncoder" /> 表示引用自定义的加密器。

结果示例

结果示例图

源码

点击下载源码

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 135,087评论 19 139
  • Spring Boot 参考指南 介绍 转载自:https://www.gitbook.com/book/qbgb...
    毛宇鹏阅读 46,989评论 6 342
  • 国家电网公司企业标准(Q/GDW)- 面向对象的用电信息数据交换协议 - 报批稿:20170802 前言: 排版 ...
    庭说阅读 11,242评论 6 13
  • 鲁迅先生绝对是中国近现代以来骨头最硬的文学家,没有之一。他描写的当时的民族劣根性至今依然存在,非常佩服他看人看事入...
    英天阅读 1,758评论 0 5
  • |你的努力暂时还撑不起你的野心 大四这年搬出去住,恰好住进了高档小区,小区别的不说,一排排的豪车,一栋栋别墅,大大...
    南面有风阅读 675评论 4 13