1. 程式人生 > >常用的幾個PHP加密函數

常用的幾個PHP加密函數

ali 對稱 上傳文件 解密 嚴格 布爾值 客戶端 base64加密 ash

閱讀目錄

  • 1、前言
  • 2、不可逆加密函數
  • 3、可逆轉的j加密函數
回到頂部

1、前言

PHP加密方式分為單項散列加密,對稱加密,非對稱加密這幾類。   像常用的MD5、hash、crypt、sha1這種就是單項散列加密,單項散列加密是不可逆的。   像URL編碼、base64編碼這種就是對稱加密,是可逆的,就是說加密解密都是用的同一秘鑰。   除此外就是非對稱加密,加密和解密的秘鑰不是同一個,如果從安全性而言,加密的信息如果還想著再解密回來,非對稱加密無疑是最為安全的方式。 回到頂部

2、不可逆加密函數

(一)、md5 string md5 ( string str[,boolraw_output = false ] ) 1.md5()默認情況下以 32 字符十六進制數字形式返回散列值,它接受兩個參數,第一個為要加密的字符串,第二個為raw_output的布爾值,默認為false,如果設置為true,md5()則會返回原始的 16 位二進制格式報文摘要 2.md5()為單向加密,沒有逆向解密算法,但是還是可以對一些常見的字符串通過收集,枚舉,碰撞等方法破解 (二)、Crypt string crypt ( string str[,stringsalt ] ) 1.crypt()接受兩個參數,第一個為需要加密的字符串,第二個為鹽值(就是加密幹擾值,如果沒有提供,則默認由PHP自動生成【鹽值只能取兩位】);返回散列後的字符串或一個少於 13 字符的字符串,後者為了區別鹽值。 2.crypt()為單向加密,跟md5一樣。 (三)、sha1 string sha1 ( string str[,boolraw_output = false ] 1.跟md5很像,不同的是sha1()默認情況下返回40個字符的散列值,傳入參數性質一樣,第一個為加密的字符串,第二個為raw_output的布爾值,默認為false,如果設置為true,sha1()則會返回原始的20 位原始格式報文摘要 2.sha1()也是單向加密,沒有逆向解密算法 (四)、hash string hash($ago,$data); 1、$ago是可以指定加密使用的哈希算法,例如:"md5","sha256","haval160,4" 等。$data是要加密的數據 hash加密也是不可逆的,因為是給定一個不確定的字符串返回特定長度的字符串,這個本質意義上來說實現了單項散列加密。 回到頂部

3、可逆轉的j加密函數

(一)、Urlencode string urlencode ( string $str ) 1.一個參數,傳入要加密的字符串(通常應用於對URL的加密), 2.urlencode為雙向加密,可以用urldecode來加密(嚴格意義上來說,不算真正的加密) 3.返回字符串,此字符串中除了 -_. 之外的所有非字母數字字符都將被替換成百分號(%)後跟兩位十六進制數,空格則編碼為加號(+)。 (二)、base64編碼 string base64_decode ( string $encoded_data ) 1.base64_encode()接受一個參數,也就是要編碼的數據(這裏不說字符串,是因為很多時候base64用來編碼圖片) 2.base64_encode()為雙向加密,可用base64_decode()來解密 base64加密本質上說就是把數據轉換為ASCLL碼,比如一個圖片進行base64編碼就會變成一堆以Ascll碼連接的字符串,這會更有利於文件的傳輸,當然base64的作用在與文件的傳輸。例如手機客戶端上傳文件到服務器,使用base64編碼可以輕松實現文件的傳輸。

常用的幾個PHP加密函數