像常用的MD5、hash、crypt、sha1這種就是單項散列加密,單項散列加密是不可逆的。
像URL編碼、base64編碼這種就是對稱加密,是可逆的,就是說加密解密都是用的同一秘鑰。
除此外就是非對稱加密,加密和解密的秘鑰不是同一個,如果從安全性而言,加密的信息如果還想著再解密回來,非對稱加密無疑是最為安全的方式。
不可逆加密函數
(一)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加密也是不可逆的,因為是給定一個不確定的字符串返回特定長度的字符串,這個本質意義上來說實現了單項散列加密。
可逆轉的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編碼可以輕松實現文件的傳輸。
-
函數
+關注
關注
3文章
4327瀏覽量
62569 -
md5
+關注
關注
0文章
29瀏覽量
20867 -
PHP
+關注
關注
0文章
452瀏覽量
26678
原文標題:常用的幾個PHP加密函數
文章出處:【微信號:Imgtec,微信公眾號:Imagination Tech】歡迎添加關注!文章轉載請注明出處。
發布評論請先 登錄
相關推薦
評論