前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Spring Security入门(三):密码加密

Spring Security入门(三):密码加密

作者头像
程序猿DD
发布2018-03-26 15:09:07
1.5K0
发布2018-03-26 15:09:07
举报
文章被收录于专栏:程序猿DD程序猿DD

前文导读

- Spring Security入门(一):登录与退出

- Spring Security入门(二):基于数据库验证

Github 地址

https://github.com/ChinaSilence/any-spring-security 本文对应 security-login-db-encryptPWD

摘要

解决2个问题:

  • 注册时密码加密后存入数据库
  • 登录时密码加密校验

运行程序

1、clone 代码

代码语言:javascript
复制
git clone https://github.com/ChinaSilence/any-spring-security.git

2、启动应用

代码语言:javascript
复制
mvn spring-boot:run

3、登录(使用账号 anoy 密码 pwd,未使用密码加密前是可以登录的)

控制台会出现如下提示:

代码语言:javascript
复制
Encoded password does not look like BCrypt

4、注册新账号并登录。

相关解释说明

相比于上一个demo,在 WebSecurityConfig 中添加了如下代码:

代码语言:javascript
复制
/**
     * 添加 UserDetailsService, 实现自定义登录校验
     */
    @Override
    protected void configure(AuthenticationManagerBuilder builder) throws Exception{
        builder.userDetailsService(anyUserDetailsService)
                .passwordEncoder(passwordEncoder());
    }

    /**
     * 密码加密
     */
    @Bean
    public BCryptPasswordEncoder passwordEncoder(){
        return new BCryptPasswordEncoder();
    }

BCryptPasswordEncoder相关知识: 用户表的密码通常使用MD5等不可逆算法加密后存储,为防止彩虹表破解更会先使用一个特定的字符串(如域名)加密,然后再使用一个随机的salt(盐值)加密。 特定字符串是程序代码中固定的,salt是每个密码单独随机,一般给用户表加一个字段单独存储,比较麻烦。 BCrypt算法将salt随机并混入最终加密后的密码,验证时也无需单独提供之前的salt,从而无需单独处理salt问题。

BCryptPasswordEncoder 是在哪里使用的?

登录时用到了 DaoAuthenticationProvider ,它有一个方法 #additionalAuthenticationChecks(UserDetails userDetails,UsernamePasswordAuthenticationTokenauthentication),此方法用来校验从数据库取得的用户信息和用户输入的信息是否匹配。

在注册时,对用户密码加密

应用 BCryptPasswordEncoder 之后,明文密码是无法被识别的,就会校验失败,只有存入密文密码才能被正常识别。所以,应该在注册时对用户密码进行加密。

代码语言:javascript
复制
/**
     * 加密密码
     */
    private void encryptPassword(UserEntity userEntity){
        String password = userEntity.getPassword();
        password = new BCryptPasswordEncoder().encode(password);
        userEntity.setPassword(password);
    }

新用户注册后,数据库中就会存入密文密码,示例:

id

username

password

nickname

roles

5

testpwd

$2a$10$i9fKauPB/mUh8pA2xHTzN.LSAu5pqmfEboNqK6y2NU9PxAt80hLc2

加密测试

ROLE_USER

补充说明:即使不同的用户注册时输入相同的密码,存入数据库的密文密码也会不同。

本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2018-01-17,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 程序猿DD 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 前文导读
  • Github 地址
  • 摘要
  • 运行程序
  • 相关解释说明
    • BCryptPasswordEncoder 是在哪里使用的?
      • 在注册时,对用户密码加密
      相关产品与服务
      数据库
      云数据库为企业提供了完善的关系型数据库、非关系型数据库、分析型数据库和数据库生态工具。您可以通过产品选择和组合搭建,轻松实现高可靠、高可用性、高性能等数据库需求。云数据库服务也可大幅减少您的运维工作量,更专注于业务发展,让企业一站式享受数据上云及分布式架构的技术红利!
      领券
      问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档