php安全密码加密算法_php加密算法小结

#加密算法

header('content-type:text/html;charset=utf-8;');

$password='hugehugehuge';

$pwd='hugehuge';

//MD5加密,单向加密算法,两个参数,1必写,要加密的字符串,

//2第二个参数是bool值,为真, MD5 报文摘要将以16字节长度的原始二进制格式返回。返回32位字符串

echo 'md5默认调用:
';

echo md5($password);

echo "
";

echo 'md5配置第二个参数调用:
';

echo md5($password,true);

//cryp,单向加密算法,两个参数,1.参数要加密的明文,它也只使用该明文的开始 8 个字符

//2。加密的干扰串,默认是两位,如果不写,则由系统随机生成两位字符,也叫做盐值或密钥。

echo '
';

echo '


';

echo "CRYPT加密算法
";

echo crypt($password);

echo '
';

echo crypt($password,'hu');

if(CRYPT_STD_DES){//CRYPTDES标准算法

echo '
标准算法,只取两位字符串作为干扰串';

echo '
';

echo crypt($password,'this is a test');

echo '
pwd:';

echo crypt($pwd,'this is a test');

echo '看两个结果是否一样
';

}

if(CRYPT_MD5){//md5加密

echo '
md5加密算法,第二个参数以$1$开头,以$结尾,最多12位作为干扰串包括$1$';

echo "
";

echo crypt($password,'$1$hellohellohello$');

echo "
pwd:";

echo crypt($pwd,'$1$hellohellohello$');

}

//sha1加密算法,返回40位长度的字符串,单向加密算法

echo '


sha1默认调用:
';

echo sha1($password);

echo "
";

echo 'md5配置第二个参数调用:
';

echo sha1($password,true);

//url加密和解密

//urlencode,传入字符串中除了-_.之外的所有非字母数字字符串都将

//被替换成百分号(%)后跟两位16进制数,空格则编码为加号(+)

echo '


url加密和解密
';

$url1='this is a url';

echo urlencode($url1);

echo '
';

$url2='www.qdweb.com?username=2+3%4 huge &king # or \1=1';

echo urlencode($url2);

/*

常用的转换

?变成 %3F

=变成 %3D

空格 变成 +

% 变成 %25

& 变成 %26

\ 变成 %5C

+ 变成 %2B

*/

echo '
urldecode的一个用处:合并参数,
';

if(!empty($_GET)){

print_r($_GET);

}

echo '
';

$url3='http://www.qdweb.com/jiami.php?username=huge&age=24';

echo 'urldecode合并参数';

$baidu='http://www.baidu.com/s?wd=%E6%85%95%E8%AF%BE%E7%BD%91%20immoc&ie=utf-8&tn=baiduhome_pg&f=8&rsv_bp=1&rsv_spt=1&rsv_sug3=6&rsv_sug4=109&rsv_sug1=3&rsv_n=2&inputT=8408&rsv_sug=1&bs=immoc%20%20%E6%85%95%E8%AF%BE%E7%BD%91';

echo '
';

echo 'rawurlencode:';

//按照RFC1738进行编码,将空格转换20%,其他同上

echo rawurlencode($url2);

#解码

$url='this is a test!';

$enurl=urlencode($url);

echo '
urlencode编码后:'.$enurl;

$deurl=urldecode($enurl);

echo '
urlencode解码后:'.$deurl;

#解码

$url='this is a test!';

$enurl=rawurlencode($url);

echo '
rawurlencode编码后:'.$enurl;

$deurl=rawurldecode($enurl);

echo '
rawurlencode反编码后:'.$deurl;

//urldecode也可以将20%解码成空格

$deurl=urldecode($enurl);

echo '
urlencode解码rawurlencode编码后的字符串:'.$deurl;

//base64_encode(),使用base64对传入字符串进行编码

//一般用在邮件中,对二进制图片进行编码

$data='虎哥是男神!!';

echo '


base64_encode加密后:';

$endata=base64_encode($data);

echo $endata;

//base64_decode(data,bool strict),对使用MIME base64编码的数据进行解码

//如果输入的数据超出了base64字母表,则返回false

echo '
base64_decode解密后:';

echo base64_decode($endata);

?>

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值