Pure Crystal implementation of the Bcrypt algorithm by Niels Provos and David Mazières, as presented at USENIX in 1999.
The algorithm has a maximum password length limit of 71 characters (see this comment on stackoverflow).
Refer to Crypto::Bcrypt::Password for a higher level interface.
About the Cost
Bcrypt, like the PBKDF2 or scrypt ciphers, are designed to be slow, so generating rainbow tables or cracking passwords is nearly impossible. Yet, computers are always getting faster and faster, so the actual cost must be incremented every once in a while. Always use the maximum cost that is tolerable, performance wise, for your application. Be sure to test and select this based on your server, not your home computer.
Last but not least: beware of denial of services! Always protect your application using an external strategy (eg: rate limiting), otherwise endpoints that verifies bcrypt hashes will be an easy target.
NOTE To use Bcrypt, you must explicitly import it with require "crypto/bcrypt"
4..31 11 1..72 16 Creates a new Crypto::Bcrypt object from the given password with salt and cost.
Creates a new Crypto::Bcrypt object from the given password with salt in bytes and cost.
Hashes the password using bcrypt algorithm using salt obtained via Random::Secure.random_bytes(SALT_SIZE).
Appends a String representation of this object which includes its class name, its object address and the values of all instance variables.
Appends a short String representation of this object which includes its class name and its object address.
Returns a nicely readable and concise string representation of this object, typically intended for users.
Reference
Reference
Reference
Object
Object
Object
Creates a new Crypto::Bcrypt object from the given password with salt and cost.
salt must be a base64 encoded string of 16 bytes (128 bits).
require "crypto/bcrypt" password = Crypto::Bcrypt.new "secret", "CJjskaIgXR32DJYjVyNPdA==" password.to_s # => "$2a$11$CJjskaIgXR32DJYjVyNPd./ajV3Yj6GiP0IAI6rR.fMnjRgozqqqG"
Creates a new Crypto::Bcrypt object from the given password with salt in bytes and cost.
require "crypto/bcrypt" password = Crypto::Bcrypt.new "secret".to_slice, "salt_of_16_chars".to_slice password.digest
Hashes the password using bcrypt algorithm using salt obtained via Random::Secure.random_bytes(SALT_SIZE).
require "crypto/bcrypt" Crypto::Bcrypt.hash_secret "secret"
Appends a String representation of this object which includes its class name, its object address and the values of all instance variables.
class Person
def initialize(@name : String, @age : Int32)
end
end
Person.new("John", 32).inspect # => #<Person:0x10fd31f20 @name="John", @age=32> Appends a short String representation of this object which includes its class name and its object address.
class Person
def initialize(@name : String, @age : Int32)
end
end
Person.new("John", 32).to_s # => #<Person:0x10a199f20>
© 2012–2026 Manas Technology Solutions.
Licensed under the Apache License, Version 2.0.
https://crystal-lang.org/api/1.19.0/Crypto/Bcrypt.html