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

php加密算法小结,古老的榕树,5-wow.com

郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。