當前位置: 首頁>>代碼示例>>Java>>正文


Java BCrypt類代碼示例

本文整理匯總了Java中org.mindrot.jbcrypt.BCrypt的典型用法代碼示例。如果您正苦於以下問題:Java BCrypt類的具體用法?Java BCrypt怎麽用?Java BCrypt使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。


BCrypt類屬於org.mindrot.jbcrypt包,在下文中一共展示了BCrypt類的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: createUser

import org.mindrot.jbcrypt.BCrypt; //導入依賴的package包/類
@Transactional
public User createUser(String username, String firstName, String lastName, String email, String password,
                       String affiliation) {
    User user = new User();

    user.setUsername(username);
    user.setFirstname(firstName);
    user.setLastname(lastName);
    user.setEmail(email);
    user.setPassword(BCrypt.hashpw(password, BCrypt.gensalt()));
    user.setRoles(Collections.singletonList(SecurityRole.findByName(DEFAULT_ROLE)));
    user.setAffiliation(affiliation);
    user.setCreatedOn(new Date());

    user.save();
    return user;
}
 
開發者ID:kurator-org,項目名稱:kurator-web,代碼行數:18,代碼來源:UserDao.java

示例2: userSignUp

import org.mindrot.jbcrypt.BCrypt; //導入依賴的package包/類
public Credentials userSignUp(Credentials credentials) throws DAOException{
    if (getUserByEmail(dao,credentials.getEmailAddress())!=null){
        throw new DAOException(HttpStatus.SC_CONFLICT,"User Already Exists");
    }
    ServerCredentials toSave = new ServerCredentials(credentials);

    toSave.decryptPassword(keyManager.getPrivateKey()); //decrypt the password
    String de = toSave.getPassword();
    String ha = BCrypt.hashpw(de, BCrypt.gensalt(10));

    toSave.setOwnerId(dao.count(Credentials.class.getName()) + 1);
    toSave.setPassword(ha); //hash the password for storage
    toSave.setAuthToken(AuthTokenUtils.getNewToken(keyManager.getSymmetricKey(), toSave));
    toSave.setRecoveryToken(AuthTokenUtils.getNewToken(keyManager.getSymmetricKey(), toSave));

    dao.save(toSave);

    return toSave;
}
 
開發者ID:williamwebb,項目名稱:divide,代碼行數:20,代碼來源:AuthServerLogic.java

示例3: login

import org.mindrot.jbcrypt.BCrypt; //導入依賴的package包/類
/**
 * Logs in the user with email address and password.
 * Returns the user on success.
 *
 * @param email The user's email address.
 * @param password The user's plain text password.
 * @return the user details.
 */
public NewCookie login(final String email, final String password) {
    final SecurityUser candidate = dao.findUserByEmail(userClass, email);
    if (candidate == null) {
        throw new BadRequestException("notfound");
    }

    if (candidate.getPasswordHash() == null) {
        throw new BadRequestException("invalid");
    }

    if (!BCrypt.checkpw(password, candidate.getPasswordHash())) {
        throw new BadRequestException("incorrect");
    }

    return loginAs(candidate);
}
 
開發者ID:minijax,項目名稱:minijax,代碼行數:25,代碼來源:Security.java

示例4: changePassword

import org.mindrot.jbcrypt.BCrypt; //導入依賴的package包/類
/**
 * Changes the current user's password.
 *
 * @param oldPassword The old password.
 * @param newPassword The new password.
 * @param confirmNewPassword The confirmed new password.
 */
public void changePassword(final String oldPassword, final String newPassword, final String confirmNewPassword) {
    requireLogin();

    if (user.getPasswordHash() == null) {
        throw new BadRequestException("unset");
    }

    if (!BCrypt.checkpw(oldPassword, user.getPasswordHash())) {
        throw new BadRequestException("incorrect");
    }

    if (!newPassword.equals(confirmNewPassword)) {
        throw new BadRequestException("mismatch");
    }

    if (newPassword.length() < MINIMUM_PASSWORD_LENGTH) {
        throw new BadRequestException("short");
    }

    user.setPassword(newPassword);
    dao.update(user);
}
 
開發者ID:minijax,項目名稱:minijax,代碼行數:30,代碼來源:Security.java

示例5: authenticate

import org.mindrot.jbcrypt.BCrypt; //導入依賴的package包/類
/**
 * Performs authentication on the provided employee.
 *
 * @param employeeId The id number of the employee to authenticate.
 *
 * @param plaintextPassword The plaintext password of the employee.
 *
 * @return The appropriate authenticationResult enum type.
 */
public AuthenticationResult authenticate(Long employeeId, String plaintextPassword) {
    Employee employee = getEmployeeById(employeeId);
    String hashed; // The encrypted (hashed) password of the employee.
    try {
        hashed = employee.getHashedPassword();
    } catch (EntityNotFoundException e) {
        return AuthenticationResult.FAILURE;
    }

    boolean passwordCorrect = BCrypt.checkpw(plaintextPassword, hashed);
    if(passwordCorrect) {
        return AuthenticationResult.SUCCESS;
    } else {
        return AuthenticationResult.FAILURE;
    }
}
 
開發者ID:maillouxc,項目名稱:git-rekt,代碼行數:26,代碼來源:EmployeeService.java

示例6: testUsers

import org.mindrot.jbcrypt.BCrypt; //導入依賴的package包/類
@Test
public void testUsers() throws Exception {
    //FileUserController.load();
    IUser user = new User();
    user.setEmail("[email protected]");
    user.setBcryptedPassword(BCrypt.hashpw("foxywords", BCrypt.gensalt()));
    user.setUsername(user.getEmail());
    user.setFamilyName("Von Colt");
    user.setGivenName("Wolfgang");
    UserController.instance().save(user);

    User existing = (User) UserController.instance().forId(user.getId());
    Assert.assertEquals(existing.getEmail(), user.getEmail());

    existing = (User) UserController.instance().forUniqueKey("email", user.getEmail());
    Assert.assertEquals(user.getGivenName(), existing.getGivenName());


}
 
開發者ID:StallionCMS,項目名稱:stallion-core,代碼行數:20,代碼來源:UsersTests.java

示例7: updateUser

import org.mindrot.jbcrypt.BCrypt; //導入依賴的package包/類
@Transactional
public User updateUser(String email, String username, String firstName, String lastName, String password,
                       String affiliation) {
    User user = User.find.where().eq("email", email).findUnique();

    user.setUsername(username);
    user.setFirstname(firstName);
    user.setLastname(lastName);
    user.setEmail(email);
    user.setPassword(BCrypt.hashpw(password, BCrypt.gensalt()));
    user.setRoles(Collections.singletonList(SecurityRole.findByName(DEFAULT_ROLE)));
    user.setAffiliation(affiliation);
    user.setLastActive(new Date());

    user.update();
    return user;
}
 
開發者ID:kurator-org,項目名稱:kurator-web,代碼行數:18,代碼來源:UserDao.java

示例8: changePassword

import org.mindrot.jbcrypt.BCrypt; //導入依賴的package包/類
public Result changePassword() {
    Form<ChangePass> form = formFactory.form(ChangePass.class).bindFromRequest();

    if (form.hasErrors()) {
        return badRequest(settings.render(form));
    }

    ChangePass changePass = form.get();

    // Get the currently logged in user
    long uid = Long.parseLong(session().get("uid"));
    User user = User.find.byId(uid);

    // Update the password
    String pass = changePass.getPassword();
    String hash = BCrypt.hashpw(pass, BCrypt.gensalt());

    user.setPassword(hash);
    user.save();

    flash("message", "Successfully updated your password.");

    return redirect(
            routes.Application.settings()
    );
}
 
開發者ID:kurator-org,項目名稱:kurator-web,代碼行數:27,代碼來源:Users.java

示例9: setPassword

import org.mindrot.jbcrypt.BCrypt; //導入依賴的package包/類
@Override
public void setPassword(String password) {
	if (((getEncryption() == 0) || (!password.equalsIgnoreCase(getPassword()))) && (_um != null)) {
		String pass;
		switch (_um.getPasscrypt()) {
			case 1: pass = Encrypt(password,"MD2"); setEncryption(1); break;
			case 2: pass = Encrypt(password,"MD5"); setEncryption(2); break;
			case 3: pass = Encrypt(password,"SHA-1"); setEncryption(3); break;
			case 4: pass = Encrypt(password,"SHA-256"); setEncryption(4); break;
			case 5: pass = Encrypt(password,"SHA-384"); setEncryption(5); break;
			case 6: pass = Encrypt(password,"SHA-512"); setEncryption(6); break;
			case 7: pass = BCrypt.hashpw(password, BCrypt.gensalt(_workload)); setEncryption(7); break;
			default: pass = password; setEncryption(0); break;
		}

		if (pass != null) {
			if (pass.length() < 2) {
				logger.debug("Failed To Set Password, Length Too Short");
			} else {
				super.setPassword(pass);
			}
		}
	} else {
		super.setPassword(password);
	}
}
 
開發者ID:drftpd-ng,項目名稱:drftpd3,代碼行數:27,代碼來源:EncryptedBeanUser.java

示例10: getUser

import org.mindrot.jbcrypt.BCrypt; //導入依賴的package包/類
public static Optional<UserPermission> getUser(String username, String password) {
    if (username == null || password == null || !users.containsKey(username)) {
        return Optional.empty();
    }

    try {
        UserPermission perm = users.get(username);
        if (!BCrypt.checkpw(password, perm.getPassword())) {
            return Optional.empty();
        }

        return Optional.of(perm);
    } catch (IllegalArgumentException ignored) {
        return Optional.empty();
    }
}
 
開發者ID:Valandur,項目名稱:Web-API,代碼行數:17,代碼來源:Users.java

示例11: login

import org.mindrot.jbcrypt.BCrypt; //導入依賴的package包/類
/**
 * Login method which tries to lookup user with given email and password.
 *
 * @return Redirection link.
 */
public String login() {
    FacesContext facesContext = FacesContext.getCurrentInstance();
    User user = userService.findByEmail(email);
    if (user == null || user.getPassword() == null
            || !BCrypt.checkpw(password, user.getPassword())) {
        ResourceBundle bundle = ResourceBundle.getBundle("messages",
                facesContext.getViewRoot().getLocale());
        facesContext.addMessage(null, new FacesMessage(FacesMessage
                .SEVERITY_FATAL, bundle.getString("common.error"),
                bundle.getString("login.fail")));
        return "";
    }
    user.setLastActivity(DateUtil.getDateTime());
    user = userService.update(user);
    facesContext.getExternalContext().getSessionMap().put(Constants.SESSION_MAP_KEY_USER, user);
    return PATH_TO_COURSE_OVERVIEW;
}
 
開發者ID:stefanoberdoerfer,項目名稱:exmatrikulator,代碼行數:23,代碼來源:LoginController.java

示例12: initUserFromInput

import org.mindrot.jbcrypt.BCrypt; //導入依賴的package包/類
/**
 * Initialises the user object from the user input.
 * @Pre The user input(email,password,firstname,lastname) is valid.
 * @return The generated registered User Object.
 */
private User initUserFromInput() {
    final String hashPW = BCrypt.hashpw(password, BCrypt.gensalt());
    final User newUser = new User();

    /* Don't set language here. Only set the language column if the user
     * explicitly requested it by changing his settings. JSF determines the
     * locale it should use by looking at the HTTP Accept-Language Header.
     * If it isn't set it uses the default-locale set in our
     * faces-config.xml. */

    newUser.setEmail(email);
    newUser.setPassword(hashPW);
    newUser.setFirstName(firstName);
    newUser.setLastName(lastName);
    newUser.setSalutation(salutation);
    newUser.setMatriculationNumber(matriculationNumber);
    newUser.addRole(GlobalRole.USER);
    newUser.setLastActivity(DateUtil.getDateTime());
    return newUser;
}
 
開發者ID:stefanoberdoerfer,項目名稱:exmatrikulator,代碼行數:26,代碼來源:RegistrationController.java

示例13: respondWith200_whenCreateAToken_ifProvidedBothAccountIdAndDescription

import org.mindrot.jbcrypt.BCrypt; //導入依賴的package包/類
@Test
public void respondWith200_whenCreateAToken_ifProvidedBothAccountIdAndDescription() throws Exception {
    String newToken = createTokenFor(validTokenPayload)
            .statusCode(200)
            .body("token", is(notNullValue()))
            .extract().path("token");

    int apiKeyHashSize = 32;
    String tokenApiKey = newToken.substring(0, newToken.length() - apiKeyHashSize);
    String hashedToken = BCrypt.hashpw(tokenApiKey, SALT);

    Optional<String> newTokenDescription = app.getDatabaseHelper().lookupColumnForTokenTable("description", TOKEN_HASH_COLUMN, hashedToken);

    assertThat(newTokenDescription.get(), equalTo(TOKEN_DESCRIPTION));

    Optional<String> newTokenAccountId = app.getDatabaseHelper().lookupColumnForTokenTable("account_id", TOKEN_HASH_COLUMN, hashedToken);
    assertThat(newTokenAccountId.get(), equalTo(ACCOUNT_ID));

    Optional<String> newCreatedByEmail = app.getDatabaseHelper().lookupColumnForTokenTable("created_by", TOKEN_HASH_COLUMN, hashedToken);
    assertThat(newCreatedByEmail.get(), equalTo(USER_EMAIL));

    Optional<String> newTokenType = app.getDatabaseHelper().lookupColumnForTokenTable("token_type", TOKEN_HASH_COLUMN, hashedToken);
    assertThat(newTokenType.get(), equalTo(CARD.toString()));
}
 
開發者ID:alphagov,項目名稱:pay-publicauth,代碼行數:25,代碼來源:PublicAuthResourceITest.java

示例14: authenticate

import org.mindrot.jbcrypt.BCrypt; //導入依賴的package包/類
@Override public Optional<User> authenticate(BasicCredentials credentials)
    throws AuthenticationException {
  User user = null;
  String username = credentials.getUsername();
  if (!User.isSanitizedUsername(username)) {
    logger.info("Username: {} must match pattern: {}", username, User.USERNAME_PATTERN);
    return Optional.empty();
  }

  String password = credentials.getPassword();

  // Get hashed password column from BCrypt table by username
  Optional<String> optionalHashedPwForUser = userDAO.getHashedPassword(username);
  if (!optionalHashedPwForUser.isPresent()) {
    return Optional.empty();
  }

  if (BCrypt.checkpw(password, optionalHashedPwForUser.get())) {
    user = User.named(username);
  }

  return Optional.ofNullable(user);
}
 
開發者ID:square,項目名稱:keywhiz,代碼行數:24,代碼來源:BcryptAuthenticator.java

示例15: updateUser

import org.mindrot.jbcrypt.BCrypt; //導入依賴的package包/類
@Override
public String updateUser(final String userName, final String emailAddress, final String hashedPassword) {
  final INode remote = MessageContext.getSender();
  if (!userName.equals(remote.getName())) {
    logger.severe("Tried to update user permission, but not correct user, userName:" + userName + " node:" + remote);
    return "Sorry, but I can't let you do that";
  }

  final DBUser user = new DBUser(
      new DBUser.UserName(userName),
      new DBUser.UserEmail(emailAddress));
  if (!user.isValid()) {
    return user.getValidationErrorMessage();
  }
  final HashedPassword password = new HashedPassword(hashedPassword);

  try {
    new UserController().updateUser(user,
        password.isHashedWithSalt() ? password : new HashedPassword(BCrypt.hashpw(hashedPassword, BCrypt.gensalt())));
  } catch (final IllegalStateException e) {
    return e.getMessage();
  }
  return null;
}
 
開發者ID:triplea-game,項目名稱:triplea,代碼行數:25,代碼來源:UserManager.java


注:本文中的org.mindrot.jbcrypt.BCrypt類示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。