国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 語言 > PHP > 正文

PHP內置加密函數詳解

2024-05-04 23:52:39
字體:
來源:轉載
供稿:網友

Md5()加密算法

方式: 單向加密

語法: md5(string $str [, bool $raw_output = false])

$str:原始字符串

$raw_output:如果可選的raw_output被設置為true, 那么md5報文摘要將以16字節長度的原始二進制格式返回. 返回以32位字符十六進制數字形式返回散列值

md5二次加密:md5(md5($string, true))

Crypt()加密算法

方式: 單向加密

語法: string crypt(string $str[, string $salt]) , 返回一個基于標準UNIX DES算法或系統上其它可用的替代算法的三列字符串

$str: 需要加密的明文

$salt: 加密時的干擾串,是編碼更安全

注意: 如果加密時沒有加上這個$salt參數, 將隨機生成一個干擾串, 否則刷新加密秘文不變

算法常量:

[CRYPT_SALT_LENGTH]

默認的加密長度。使用標準的 DES 加密,長度為 2

[CRYPT_STD_DES]

基于標準 DES 算法的散列使用 "./0-9A-Za-z" 字符中的兩個字符作為鹽值。在鹽值中使用非法的字符將導致 crypt() 失敗。

[CRYPT_EXT_DES]

擴展的基于 DES 算法的散列。其鹽值為 9 個字符的字符串,由 1 個下劃線后面跟著 4 字節循環次數和 4 字節鹽值組成。它們被編碼成可打印字符,每個字符 6 位,有效位最少的優先。0 到 63 被編碼為 "./0-9A-Za-z"。在鹽值中使用非法的字符將導致 crypt() 失敗。

[CRYPT_MD5]

MD5 散列使用一個以 $1$ 開始的 12 字符的字符串鹽值。

[CRYPT_BLOWFISH]

Blowfish 算法使用如下鹽值:“$2a$”,一個兩位 cost 參數,“$” 以及 64 位由 “./0-9A-Za-z” 中的字符組合而成的字符串。在鹽值中使用此范圍之外的字符將導致 crypt() 返回一個空字符串。兩位 cost 參數是循環次數以 2 為底的對數,它的范圍是 04-31,超出這個范圍將導致 crypt() 失敗。

CRYPT_SHA256

SHA-256 算法使用一個以 $5$ 開頭的 16 字符字符串鹽值進行散列。如果鹽值字符串以 “rounds=<N>$” 開頭,N 的數字值將被用來指定散列循環的執行次數,這點很像 Blowfish 算法的 cost 參數。默認的循環次數是 5000,最小是 1000,最大是 999,999,999。超出這個范圍的 N 將會被轉換為最接近的值。

CRYPT_SHA512

SHA-512 算法使用一個以 $6$ 開頭的 16 字符字符串鹽值進行散列。如果鹽值字符串以 “rounds=<N>$” 開頭,N 的數字值將被用來指定散列循環的執行次數,這點很像 Blowfish 算法的 cost 參數。默認的循環次數是 5000,最小是 1000,最大是 999,999,999。超出這個范圍的 N 將會被轉換為最接近的值。

例:

if(CRYPT_MD5){  echo "MD5加密:".crypt('something','$1$somethin$');}

Sha1()加密算法

方式: 單向加密

語法: string sha1(string $str [, bool $raw_output=false]) 計算字符串的sha1散列值

$str: 加密的字符串

$raw_output: 如果可選的raw_output參數被設置為TRUE, 那么sha1摘要將以20字符長度的原始格式返回, 否則返回值是一個40字符串長度的十六進制數字.

URL編碼加密技術

編碼URL字符串: urlencode(string $str)

解碼已編碼的URL字符串: urldeocde(string $str)

編碼規范: 此字符串中除了-_.之外的所有非字母數字字符都將被替換成百分號(%)后跟兩位十六進制數, 空格則編碼為加號(+)

按照RFC1738對URL進行編碼: rawurlencode(string $str) : 返回從字符串,把空格編碼為%20

對已編碼的字符串進行解碼: rawurldecode(string $str) : 返回字符串, 此字符串中百分號%后跟兩位十六進制的序列豆將被替換成原義字符

urlencode和rawurlencode的區別只在于空格.

Base64編碼加密技術

使用base64對data進行編碼: base64_encode(string $data)

對使用MIME base64編碼的數據進行解碼: base64_decode(string $data[, $strict=false]) ; $strict:如果輸入的數據超出了base64的字母表,則返回false.

base64編碼的圖片還可以直接放在<img>標簽中顯示:

<img src="data:image/jpeg;base64,編碼字符串" alt=""/>

<img src="data:;base64,編碼字符串" alt=""/>

信息加密技術:

1 單項散列加密:

指通過不同輸入的長度的信息進行散列計算, 得到固定長度的輸出, 這個散列計算過程是單向的, 既不能對固定長度的輸出進行計算從而活兒輸出信息.

2 對稱散列加密

指加密和解密的密匙是同一個密匙或者可以互相推算.

3 非對稱散列加密

非對稱加密和解密的密匙不是同一個密匙, 其中一個對外公開, 被稱作公鑰, 另一個只有所有者知道.


注:相關教程知識閱讀請移步到PHP教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

主站蜘蛛池模板: 沈阳市| 泾川县| 乌拉特中旗| 格尔木市| 井陉县| 同德县| 洛扎县| 宁强县| 黑河市| 富川| 松阳县| 海丰县| 陇西县| 河北区| 陵水| 萨嘎县| 扎鲁特旗| 石楼县| 陆良县| 云梦县| 长春市| 余庆县| 丹阳市| 乡城县| 涞水县| 新野县| 峨眉山市| 香河县| 永嘉县| 德江县| 廉江市| 开阳县| 嘉祥县| 宝鸡市| 镶黄旗| 阜阳市| 社会| 马鞍山市| 政和县| 潮州市| 德钦县|