广东IT优就业
阅读目录
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编码可以轻松实现文件的传输。
广东IT优就业
希望广州IT培训老师上述分享的内容对大家有所帮助。
出处:https://www.cnblogs.com/phpstudy2015-6/p/8072094.html
更多IT精彩推举:
吸金能力者-PHP工程师:http://www.ujiuye.com/zt/php/?wt.mc_id=17009338