常用的幾個PHP加密函數


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編碼可以輕松實現文件的傳輸。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM