转为密码存储设计的散列算法:bcrypt

一、bcrypt是什么?

bcrypt是专为密码存储设计的散列算法,具有很高的安全性。

二、bcrypt算法的特别

1.盐值:bcrypt为每一个用户生成唯一的盐值并包含在散列中,即使用户设置了相同的密码,其散列值也是不同的。

2.抗彩虹表攻击: 由于每个散列值都有不同的盐值,即使使用预计算的彩虹表也无法直接破解bcrypt散列值。

三、代码示例

1.添加依赖

pom.xml中添加依赖

<dependency>
    <groupId>org.mindrot</groupId>
    <artifactId>jbcrypt</artifactId>
    <version>0.4</version>
</dependency>

2.示例

import org.mindrot.jbcrypt.BCrypt;

public class BcryptExample {
    public static String hashPassword(String password){
        //生成一个随机盐值
        String salt = BCrypt.gensalt();
        //生成包含盐值的密码散列
        return BCrypt.hashpw(password,salt);
    }
    public static boolean checkPassword(String plainPassword,String hashedPassword{
        
        //使用BCrypt库检查密码是否匹配 
        return BCrypt.checkpw(plainPassword,hashedPassword);
    }

    public static void main(String[] args) {
        String originalPassword = "mySecurePassword";
        //调用hashPassword方法对原始密码进行散列处理
        String hashedPassword = hashPassword(originalPassword);
        System.out.println("Original Password:" + originalPassword);
        System.out.println("Hashed Password:" + hashedPassword);
        //验证密码
        boolean isPasswordCorrect = checkPassword(originalPassword,hashedPassword);
        System.out.println("Password is correct:" + isPasswordCorrect);
        boolean isPasswordIncorrect = checkPassword("wrongPassword",hashedPassword);
        System.out.println("Password is correct:" +isPasswordIncorrect);
    }
}

运行结果:

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值