当前位置: 代码迷 >> 综合 >> 网络攻防 | WEB2
  详细解决方案

网络攻防 | WEB2

热度:94   发布时间:2024-02-28 11:33:03.0

先来看一下代码

<?php
$miwen="a1zLbgQsCESEIqRLwuQAyMwLyq2L5VwBxqGA3RQAyumZ0tmMvSGM2ZwB4tws";function encode($str){$_o=strrev($str);// echo $_o;for($_0=0;$_0<strlen($_o);$_0++){$_c=substr($_o,$_0,1); //substr()函数返回字符串$_o的一部分,从$_0开始,截取1个字符的长度$__=ord($_c)+1; //ord() 函数返回字符串中第一个字符的 ASCII 值$_c=chr($__); //chr() 函数从指定 ASCII 值返回字符$_=$_.$_c;  //.用来连接字符串 } return str_rot13(strrev(base64_encode($_)));
}highlight_file(__FILE__);
/*逆向加密算法,解密$miwen就是flag
*/
?>

方法一:先用在线工具解码,再层层解密

只要按照php的加密方式反过来解密就可以了

具体流程:rot13解码——翻转字符串——base64解码——encode函数反向解码

密文:a1zLbgQsCESEIqRLwuQAyMwLyq2L5VwBxqGA3RQAyumZ0tmMvSGM2ZwB4tws

rot13解码:n1mYotDfPRFRVdEYjhDNlZjYld2Y5IjOkdTN3EDNlhzM0gzZiFTZ2MjO4gjf

翻转字符串:fjg4OjM2ZTFiZzg0MzhlNDE3NTdkOjI5Y2dlYjZlNDhjYEdVRFRPfDtoYm1n

base64解码:~88:36e1bg8438e41757d:29cgeb6e48c`GUDTO|;hbmg

encode函数反向解码:

<?php
$_='~88:36e1bg8438e41757d:29cgeb6e48c`GUDTO|;hbmg';$_o=NULL;
for($_0=0;$_0<strlen($_);$_0++){       $_c=substr($_,$_0,1);  $__=ord($_c)-1;  $_c=chr($__);  $_o=$_o.$_c;   } echo strrev($_o);
?>

方法二:直接写一个反向解密的代码

<?php
$str='a1zLbgQsCESEIqRLwuQAyMwLyq2L5VwBxqGA3RQAyumZ0tmMvSGM2ZwB4tws';
$_ = base64_decode(strrev(str_rot13($str)));$_o=NULL;
for($_0=0;$_0<strlen($_);$_0++){     $_c=substr($_,$_0,1);  $__=ord($_c)-1;  $_c=chr($__);  $_o=$_o.$_c;   } echo strrev($_o);
?>

拿到flag:flag:{NSCTF_b73d5adfb819c64603d7237fa0d52977}