php加密算法小结
<?php
#加密算法
header(‘content-type:text/html;charset=utf-8;‘);
$password=‘hugehugehuge‘;
$pwd=‘hugehuge‘;
//MD5加密,单向加密算法,两个参数,1必写,要加密的字符串,
//2第二个参数是bool值,为真, MD5 报文摘要将以16字节长度的原始二进制格式返回。返回32位字符串
echo ‘md5默认调用:<BR>‘;
echo md5($password);
echo "<BR>";
echo ‘md5配置第二个参数调用:<BR>‘;
echo md5($password,true);
//cryp,单向加密算法,两个参数,1.参数要加密的明文,它也只使用该明文的开始 8 个字符
//2。加密的干扰串,默认是两位,如果不写,则由系统随机生成两位字符,也叫做盐值或密钥。
echo ‘<br>‘;
echo ‘<hr>‘;
echo "CRYPT加密算法<BR>";
echo crypt($password);
echo ‘<br>‘;
echo crypt($password,‘hu‘);
if(CRYPT_STD_DES){//CRYPTDES标准算法
echo ‘<br>标准算法,只取两位字符串作为干扰串‘;
echo ‘<br>‘;
echo crypt($password,‘this is a test‘);
echo ‘<br>pwd:‘;
echo crypt($pwd,‘this is a test‘);
echo ‘看两个结果是否一样<br>‘;
}
if(CRYPT_MD5){//md5加密
echo ‘<br>md5加密算法,第二个参数以$1$开头,以$结尾,最多12位作为干扰串包括$1$‘;
echo "<br>";
echo crypt($password,‘$1$hellohellohello$‘);
echo "<br>pwd:";
echo crypt($pwd,‘$1$hellohellohello$‘);
}
//sha1加密算法,返回40位长度的字符串,单向加密算法
echo ‘<hr>sha1默认调用:<BR>‘;
echo sha1($password);
echo "<BR>";
echo ‘md5配置第二个参数调用:<BR>‘;
echo sha1($password,true);
//url加密和解密
//urlencode,传入字符串中除了-_.之外的所有非字母数字字符串都将
//被替换成百分号(%)后跟两位16进制数,空格则编码为加号(+)
echo ‘<hr>url加密和解密<br>‘;
$url1=‘this is a url‘;
echo urlencode($url1);
echo ‘<br>‘;
$url2=‘www.qdweb.com?username=2+3%4 huge &king # or \1=1‘;
echo urlencode($url2);
/*
常用的转换
?变成 %3F
=变成 %3D
空格 变成 +
% 变成 %25
& 变成 %26
\ 变成 %5C
+ 变成 %2B
*/
echo ‘<br>urldecode的一个用处:合并参数,<br>‘;
if(!empty($_GET)){
print_r($_GET);
}
echo ‘<br>‘;
$url3=‘http://www.qdweb.com/jiami.php?username=huge&age=24‘;
echo ‘<a href="‘.$url3.‘">urldecode合并参数</a>‘;
$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 ‘<br>‘;
echo ‘rawurlencode:‘;
//按照RFC1738进行编码,将空格转换20%,其他同上
echo rawurlencode($url2);
#解码
$url=‘this is a test!‘;
$enurl=urlencode($url);
echo ‘<br>urlencode编码后:‘.$enurl;
$deurl=urldecode($enurl);
echo ‘<br>urlencode解码后:‘.$deurl;
#解码
$url=‘this is a test!‘;
$enurl=rawurlencode($url);
echo ‘<br>rawurlencode编码后:‘.$enurl;
$deurl=rawurldecode($enurl);
echo ‘<br>rawurlencode反编码后:‘.$deurl;
//urldecode也可以将20%解码成空格
$deurl=urldecode($enurl);
echo ‘<br>urlencode解码rawurlencode编码后的字符串:‘.$deurl;
//base64_encode(),使用base64对传入字符串进行编码
//一般用在邮件中,对二进制图片进行编码
$data=‘虎哥是男神!!‘;
echo ‘<hr>base64_encode加密后:‘;
$endata=base64_encode($data);
echo $endata;
//base64_decode(data,bool strict),对使用MIME base64编码的数据进行解码
//如果输入的数据超出了base64字母表,则返回false
echo ‘<br>base64_decode解密后:‘;
echo base64_decode($endata);
?>
本文出自 “虎哥的博客” 博客,请务必保留此出处http://7613577.blog.51cto.com/7603577/1531691
郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。