首頁 >後端開發 >php教程 >php函數crypt()的加密用法總結

php函數crypt()的加密用法總結

伊谢尔伦
伊谢尔伦原創
2017-06-09 11:49:343440瀏覽

在php函數中,有不少加密的函數,其中一個可以實作資料加密功能的函數叫做crypt()函數。 crypt() 函數使用單向演算法,沒有對應的解密函數。它傳回使用 DES、Blowfish 或 MD5 演算法加密的字串。從表面上看,crypt()的函數似乎沒有什麼用處,但該函數的確被廣泛用來保證系統密碼的完整性。因為,單向加密的口令即使落入第三方的手裡,由於不能被還原為明文,也沒有什麼大用處。 下面我們就來對crypt()函數的使用做一些總結,希望對大家的php學習有所幫助。

crypt()函數相關內容

#1. PHP加密函數—crypt()函數加密用法實例

php函數crypt()的加密用法總結

#在介紹加密函數之前,我們先來介紹一下資料加密原理:就是對原來的明文件或資料按照某種演算法處理,使其成為不可讀的一段程式碼,通常稱之為“密文”,透過這樣的途徑來達到保護資料不被非法竊取和閱讀的目的! 在PHP中能加密資料的函數主要有:crypt()、md5()以及sha1(),還有就是加密擴充函式庫Mcrpyt和Mash。在這篇文章中,我們先介紹使用crpyt()函數來加密!

2. 使用crypt()函數進行加密-php加密技術

php函數crypt()的加密用法總結

crypt()函數是單向加密的,密文不可還原成明碼,每次加密後的資料還不相同,怎麼進行判斷呢?

——這就是salt參數要解決的問題。 crypt()函數以salt參數對明文進行加密,判斷時,對輸出的資訊再次使用相同的salt參數進行加密,對比兩次加密後的結果來進行判斷。

3. PHP中使用crypt()實作使用者驗證的程式碼

crypt()函數定義如下。 string crypt (string input_string [, string salt]) 
其中,input_string參數是需要加密的明文字串,第二個可選的salt是一個位元字符串,能夠影響加密的暗碼,進一步排除被破解的可能性。預設情況下,PHP使用一個2個字元的DES幹擾串,如果系統使用的是MD5(參考下一節內容),PHP則會使用一個12個字元的干擾串。可以透過執行下面的命令發現系統將要使用的干擾串的長度。
print "My system salt size is: ". CRYPT_SALT_LENGTH; 

4. PHP中使用crypt()實作使用者驗證

crypt() 函數傳回使用DES、Blowfish 或MD5 加密的字串。在不同的作業系統上,本函數的行為不同,某些作業系統支援一種以上的演算法類型。在安裝時,PHP 會檢查什麼演算法可用以及使用什麼演算法。 只要有一點使用非Windows平台經驗的讀者都可能對crypt()相當熟悉,這一函數完成被稱作單向加密的功能,它可以加密一些明碼,但不能反過來將密碼重新轉換為原來的明碼。

5. PHP函數crypt()的功能介紹

PHP函數crypt()中的這些加密的口令對應的明碼分別是kent、banner和parker。注意每個口令的前二個字母, 這是因為我使用了下面的代碼,根據口令的前二個字母創建幹擾串的我將使用Apache的口令-應答認證配置提示用戶輸入用戶名和口令,一個鮮為人知的有關PHP的信息是,它可以把Apache 的口令-應答系統輸入的用戶名和口令識別為$PHP_AUTH_USER和$PHP_AUTH_PW,將在身份驗證腳本中用到這二個變量。

相關問答

1. laravel5.2 openssl_encrypt() 的問題?

2. md5 - PHP:crypt()函數。請問其加密後的密值有可能等於鹽值麼?

3. 如何在Nodejs中實作PHP crypt()函數

【相關推薦】

1. 【php加密解密類別庫】10個php加密解密類別庫下載

2. php中文網路免費影片教學:《php.cn獨孤九賤(4)-php影片教學》

#

以上是php函數crypt()的加密用法總結的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn