php aec 解密sha1,PHP 加密和解密

计应134(实验班) 郑寿奎

一、crypt()函数单向加密

语法格式:

String crypt(string str[, string salt]);

参数str是需要加密的值,salt是干扰串,如果把salt省略就会随机生成一个干扰串

设置干扰串和不设置干扰串的区别:

设置干扰串之后的值是一直不会变的

不设置干扰串之后的值是随机的,每一次都不一样

代码如下:

<?php $str="这是个值";echo '加密前的值:'.$str."
";$jiami=crypt($str);echo '没有干扰串加密后的值:'.$jiami."
";$jia=crypt($str,"ab");echo '添加干扰串"ab"加密后的值:'.$jia."
";?>

第一次运行结果如下图:

53e1256c39ce2f28fef49874d1cfa32c.png

第二次运行结果如下图:

e358ed7047848c0b73cffcef5ed2ce2e.png

crypt()函数加密是单向加密的,如果不加干扰串,那么每次加密的结果都是不一样的,但是加了干扰串之后可以发现,每次的值都是一样的。

所以对加密后的数据进行判断就需要在加密之前加上干扰串

二、md5()函数加密

语法格式:

string md5(string str[, bool raw_output]);

参数str是需要加密的数据,raw_output的值是true和false,默认为false,如果为true的是后,那么函数就会返回一个二进制形式的密文

md5()函数加密的密文是一直不会变的

代码:

<?php $str="这是个值";echo '加密前的值:'.$str."
";$jiami=md5($str);echo '默认加密后的值:'.$jiami."
";$jiami=md5($str,true);echo 'true加密后的值:'.$jiami."
";?>

运行结果如下图:

a8a619296b3b77d1d2c9e972a711a070.png

三、sha1()函数加密

语法格式:

string sha1(string str[, bool raw_output]);

参数str是需要加密的数据,raw_output默认false,函数返回一个40位的十六进制数,true 返回20的二进制数

sha1()函数加密后的密文是不会变的

代码:

<?php $str="这是个值";echo '加密前的值:'.$str."
";$jiami=sha1($str);echo '默认加密后的值:'.$jiami."
";$jiami=sha1($str,true);echo 'true加密后的值:'.$jiami."
";?>

运行结果如下图:

0029152d693c7930742af39209bc0408.png

四、加密和解密

代码:

function encode($string = '', $skey = 'cxphp') {$strArr = str_split(base64_encode($string));$strCount = count($strArr);foreach (str_split($skey) as $key => $value)$key < $strCount && $strArr[$key].=$value;return str_replace(array('=', '+', '/'), array('O0O0O', 'o000o', 'oo00o'), join('', $strArr));

}//解密

function decode($string = '', $skey = 'cxphp') {$strArr = str_split(str_replace(array('O0O0O', 'o000o', 'oo00o'), array('=', '+', '/'), $string), 2);$strCount = count($strArr);foreach (str_split($skey) as $key => $value)$key <= $strCount && isset($strArr[$key]) && $strArr[$key][1] === $value && $strArr[$key] = $strArr[$key][0];return base64_decode(join('', $strArr));

}$str = '四大古典风格';echo "string : " . $str . "
";echo "encode : " . ($enstring = encode($str)) . '
';echo "decode : " . decode($enstring);?>

运行结果如下图:

7e28ead0ae0b39b6eb1e1ae089985abe.png

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值