java - 为什么来自 Spring 的 BCryptPasswordEncoder 为相同的输入生成不同的输出?

标签 java spring spring-security bcrypt

我正在使用带有 Spring 安全性的 BCryptPasswordEncoder。我的期望是,对于相同的输入,我总是会得到相同的输出。但是对于相同的输入,我得到不同的输出。您可以使用下面的代码片段对其进行测试:

String password = "123456"; 
PasswordEncoder passwordEncoder = new BCryptPasswordEncoder(); 
String encodedPassword = passwordEncoder.encode(password);
System.out.print(encodedPassword);

output: $2a$10$cYLM.qoXpeAzcZhJ3oXRLu9Slkb61LHyWW5qJ4QKvHEMhaxZ5qCPi

output2: $2a$10$KEvYX9yjj0f1X3Wl8S.KPuWzSWGyGM9ubI71NOm3ZNbJcwWN6agvW

output3: $2a$10$nCmrPtUaOLn5EI73VZ4Ouu1TmkSWDUxxD4N6A.8hPBWg43Vl.RLDC

有人能解释一下,为什么 BCryptPasswordEncoder 会这样吗?

最佳答案

public static void main(String[] args) {
  // spring 4.0.0
  org.springframework.security.crypto.password.PasswordEncoder encoder
   = new org.springframework.security.crypto.bcrypt.BCryptPasswordEncoder();

   // $2a$10$lB6/PKg2/JC4XgdMDXyjs.dLC9jFNAuuNbFkL9udcXe/EBjxSyqxW
   // true
   // $2a$10$KbQiHKTa1WIsQFTQWQKCiujoTJJB7MCMSaSgG/imVkKRicMPwgN5i
   // true
   // $2a$10$5WfW4uxVb4SIdzcTJI9U7eU4ZwaocrvP.2CKkWJkBDKz1dmCh50J2
   // true
   // $2a$10$0wR/6uaPxU7kGyUIsx/JS.krbAA9429fwsuCyTlEFJG54HgdR10nK
   // true
   // $2a$10$gfmnyiTlf8MDmwG7oqKJG.W8rrag8jt6dNW.31ukgr0.quwGujUuO
   // true

    for (int i = 0; i < 5; i++) {
      // "123456" - plain text - user input from user interface
      String passwd = encoder.encode("123456");

      // passwd - password from database
      System.out.println(passwd); // print hash

      // true for all 5 iteration
      System.out.println(encoder.matches("123456", passwd));
    }
}

关于java - 为什么来自 Spring 的 BCryptPasswordEncoder 为相同的输入生成不同的输出?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25844419/

相关文章:

java - 无法获取资源

java - 具有凭证安全性的 Spring token 安全性(spring boot)

spring-security - Spring Data JPA 和 spring-security : filter on database level (especially for paging)

带有点 (.) 的 Spring MVC @PathVariable 被截断

java - Spring异常拦截器

java - 如何理解和使用 "program API"?

java - 在 Google map 服务的 Java 客户端中获取状态并编辑查询限制

java - spring mvc登录后重定向到主页

Spring Security 与 Angular2

java - 按组动画图像列表 Java Swing