密码加密策略BCryptPasswordEncoder

BCryptPasswordEncoder这个方法来源于spring-security这个安全框架,他的主要有优点是,比起传统的MD5加密方式, 他更加的安全,暴力破解的难度更加的大,相同的明文可以生成不同的密文

1.添加依赖
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-security</artifactId>
    </dependency>

2.在启动类中加入
    @Bean
    public BCryptPasswordEncoder passwordEncoder(){
        return new BCryptPasswordEncoder();
    }

3. 引入security的jar包后,会自动生成一套登录权限,就是一个登录页面,启动的时候控制台会刷出一条password,账号默认是user,在不用这套权限框架的情况下,可以在启动类中加入以下注解,关掉权限验证
    @EnableAutoConfiguration(exclude = {org.springframework.boot.autoconfigure.security.servlet.SecurityAutoConfiguration.class })

4.测试流程

    注入实现类
    @Autowired
    private BCryptPasswordEncoder passwordEncoder;

    //生成密码
    @PostMapping("genPassWord")
    public String genPassWord(@RequestBody Map<String, String> param) {
        String jmpwd=passwordEncoder.encode(param.get("pwd"));
        return Result.succeed(jmpwd, StringConstant.OPER_SUCCESS_MSG);
    }
 
    //生成密码
    @PostMapping("testPassWord")
    public String testPassWord(@RequestBody Map<String, String> param) {
        boolean flag=passwordEncoder.matches(param.get("pwd"),param.get("jmpwd"));
        return Result.succeed(flag, StringConstant.OPER_SUCCESS_MSG);
    }    
    
    192.168.8.12:28073/order/genPassWord
    {"pwd":"123456789"}  
    
    192.168.8.12:28073/order/testPassWord
    {"pwd":"123456789","jmpwd":"$2a$10$tMuFBU4mYKfHpPOjIl7uG.KcXsSoZ2R3vgTc2rZJbA8VyrE9UecEW"}

    同样的明文123456789,生成的密文各不相同
    $2a$10$/GtzWl/YaMWtYs.v6eJazu.4QVkVAoCYWWVRa1RbklxLiUMQBWZpa
    $2a$10$tMuFBU4mYKfHpPOjIl7uG.KcXsSoZ2R3vgTc2rZJbA8VyrE9UecFq
    $2a$10$D3fNjCTsyiYSasKXLsSGbu/QtQm4BIGfqwG5VuqlAExHaQUxDsUEm
    $2a$10$ZYifiprUdycNOqjzqqvbSOLSvgAhtJfjxUlKmYAQbWyjVXNqhOHL2

    这就达成了咱们的预期目的
   

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

javachen__

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值