阿里查詢 > PHP hash函數(password_hash)在線加密 > (PHP 5 >= 5.5.0, PHP 7)
password_hash函數加密介紹,password_hash — 創建密碼的散列(hash)
password_hash() 使用足夠強度的單向散列算法創建密碼的散列(hash)。 password_hash() 兼容 crypt()。 所以, crypt() 創建的密碼散列也可用于 password_hash()。
(PHP 5 >= 5.5.0, PHP 7)
password_hash — 創建密碼的散列(hash)
string password_hash ( string $password , int $algo [, array $options ] )
當前支持的算法:
PASSWORD_DEFAULT - 使用 bcrypt 算法 (PHP 5.5.0 默認)。 注意,該常量會隨著 PHP 加入更新更高強度的算法而改變。 所以,使用此常量生成結果的長度將在未來有變化。 因此,數據庫里儲存結果的列可超過60個字符(最好是255個字符)。
PASSWORD_BCRYPT - 使用 CRYPT_BLOWFISH 算法創建散列。 這會產生兼容使用 "$2y$" 的 crypt()。 結果將會是 60 個字符的字符串, 或者在失敗時返回 FALSE。
PASSWORD_ARGON2I - 使用 Argon2 散列算法創建散列。
PASSWORD_BCRYPT 支持的選項:
salt(string) - 手動提供散列密碼的鹽值(salt)。這將避免自動生成鹽值(salt)。
省略此值后,password_hash() 會為每個密碼散列自動生成隨機的鹽值。這種操作是有意的模式。
Warning
鹽值(salt)選項從 PHP 7.0.0 開始被廢棄(deprecated)了。 現在最好選擇簡單的使用默認產生的鹽值。
cost (integer) - 代表算法使用的 cost。crypt() 頁面上有 cost 值的例子。
省略時,默認值是 10。 這個 cost 是個不錯的底線,但也許可以根據自己硬件的情況,加大這個值。
PASSWORD_ARGON2I 支持的選項:
memory_cost (integer) - 計算 Argon2 散列時的最大內存(單位:字節 byte)。默認值: PASSWORD_ARGON2_DEFAULT_MEMORY_COST。
time_cost (integer) - 計算 Argon2 散列時最多的時間。默認值: PASSWORD_ARGON2_DEFAULT_TIME_COST。
threads (integer) - 計算 Argon2 散列時最多的線程數。默認值: PASSWORD_ARGON2_DEFAULT_THREADS。
參數
password
用戶的密碼。
Caution
使用PASSWORD_BCRYPT 做算法,將使 password 參數最長為72個字符,超過會被截斷。
algo
一個用來在散列密碼時指示算法的密碼算法常量。
options
一個包含有選項的關聯數組。目前支持兩個選項:salt,在散列密碼時加的鹽(干擾字符串),以及cost,用來指明算法遞歸的層數。這兩個值的例子可在 crypt() 頁面找到。
省略后,將使用隨機鹽值與默認 cost。
返回值
返回散列后的密碼, 或者在失敗時返回 FALSE。
使用的算法、cost 和鹽值作為散列的一部分返回。所以驗證散列值的所有信息都已經包含在內。 這使 password_verify() 函數驗證的時候,不需要額外儲存鹽值或者算法的信息。
(PHP 5 >= 5.5.0, PHP 7)
password_hash — 創建密碼的散列(hash)
string password_hash ( string $password , int $algo [, array $options ] )
當前支持的算法:
PASSWORD_DEFAULT - 使用 bcrypt 算法 (PHP 5.5.0 默認)。 注意,該常量會隨著 PHP 加入更新更高強度的算法而改變。 所以,使用此常量生成結果的長度將在未來有變化。 因此,數據庫里儲存結果的列可超過60個字符(最好是255個字符)。
PASSWORD_BCRYPT - 使用 CRYPT_BLOWFISH 算法創建散列。 這會產生兼容使用 "$2y$" 的 crypt()。 結果將會是 60 個字符的字符串, 或者在失敗時返回 FALSE。
PASSWORD_ARGON2I - 使用 Argon2 散列算法創建散列。
PASSWORD_BCRYPT 支持的選項:
salt(string) - 手動提供散列密碼的鹽值(salt)。這將避免自動生成鹽值(salt)。
省略此值后,password_hash() 會為每個密碼散列自動生成隨機的鹽值。這種操作是有意的模式。
Warning
鹽值(salt)選項從 PHP 7.0.0 開始被廢棄(deprecated)了。 現在最好選擇簡單的使用默認產生的鹽值。
cost (integer) - 代表算法使用的 cost。crypt() 頁面上有 cost 值的例子。
省略時,默認值是 10。 這個 cost 是個不錯的底線,但也許可以根據自己硬件的情況,加大這個值。
PASSWORD_ARGON2I 支持的選項:
memory_cost (integer) - 計算 Argon2 散列時的最大內存(單位:字節 byte)。默認值: PASSWORD_ARGON2_DEFAULT_MEMORY_COST。
time_cost (integer) - 計算 Argon2 散列時最多的時間。默認值: PASSWORD_ARGON2_DEFAULT_TIME_COST。
threads (integer) - 計算 Argon2 散列時最多的線程數。默認值: PASSWORD_ARGON2_DEFAULT_THREADS。
參數
password
用戶的密碼。
Caution
使用PASSWORD_BCRYPT 做算法,將使 password 參數最長為72個字符,超過會被截斷。
algo
一個用來在散列密碼時指示算法的密碼算法常量。
options
一個包含有選項的關聯數組。目前支持兩個選項:salt,在散列密碼時加的鹽(干擾字符串),以及cost,用來指明算法遞歸的層數。這兩個值的例子可在 crypt() 頁面找到。
省略后,將使用隨機鹽值與默認 cost。
返回值
返回散列后的密碼, 或者在失敗時返回 FALSE。
使用的算法、cost 和鹽值作為散列的一部分返回。所以驗證散列值的所有信息都已經包含在內。 這使 password_verify() 函數驗證的時候,不需要額外儲存鹽值或者算法的信息。

常用查詢