实验吧-杂项-你没有见过的加密!(php srand()和rand()函数)

什么垃圾东西,弄半天,Windows上运行乱码,linux上7.3的php运行也是乱码(气死)。

下载文件,查看内容

<?php


	function encrypt($str)
	{
		$cryptedstr = "";
		srand(3284724);
		for ($i =0; $i < strlen($str); $i++)
		{
			$temp = ord(substr($str,$i,1)) ^ rand(0, 255);
			while(strlen($temp)<3)
			{
				$temp = "0".$temp;

			}
			$cryptedstr .= $temp. "";
		}
		return base64_encode($cryptedstr);
	}
	
?>

这个加密代码的具体流程和解密思想,仔细看看,慢慢思考思考不是很难,不要一看到代码急躁,这是完全能看懂的。

就着加密思路写解密代码:

<?php
$cryptedstr = "MDEzMjE5MDAyMTg0MTUzMjQwMTQ0MDc3MjUzMDk2MTc1MTUzMTE4MTg4MDEwMDA2MTg4MDA0MjM4MDI1MTA3MTU4MTc5MTM4";
$cryptedstr = base64_decode($cryptedstr);

$len = strlen($cryptedstr);
$str = "";
srand(3284724);
for($i=0;$i<$len/3;$i++){
	$temp = substr($cryptedstr, 0, 3);
	$cryptedstr = substr($cryptedstr, 3);
	$n = intval($temp)^rand(0, 255);
	$str .= chr($n);
}

echo "$str";



?>

气死了,最后在这里运行才拿到flag:http://www.dooccn.com/php/

知识点:1)srand()和rand()

参考:https://blog.csdn.net/zz_Caleb/article/details/87829463

2)substr()

参考:https://blog.csdn.net/zz_Caleb/article/details/87829892

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值