实验吧-杂项-你没有见过的加密!(php srand()和rand()函数)
2024-10-05 07:19:31
什么垃圾东西,弄半天,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
最新文章
- netcore - MVC的ActionFilter的使用
- html框架练习
- xib与nib的区别
- android的progressDialog 的使用。android数据异步加载 对话框提示
- HashMap实现原理分析(详解)
- windows下做react native官方例子遇到的问题
- umount nfs状态为busy的处理方法
- android 10 事件
- ViEmu for VS2013-3.2.1 破解(转)
- WebService基础学习(二)&mdash;三要素
- python3 第二十一章 - 函数式编程之return函数和闭包
- tp3.2 URL_MODEL为2 配置
- Android群英传笔记——第九章:Android系统信息和安全机制
- Java反射-修改字段值, 反射修改static final修饰的字段
- kubernetes1.14.0部署
- Mongodb Mysql NoSQL的区别和联系
- maven打包子模块中的class文件
- cpu信息查看
- php底层HashTable的实现
- Linux 网络子系统之结构介绍