今日份攻防世界11.10----web2

论坛 期权论坛 脚本     
已经匿名di用户   2022-5-29 19:05   884   0

//ord() 函数返回字符串的首个字符的 ASCII 值。

//strrev() 函数:反转字符串 strrev("I love Shanghai!");=>!iahgnahS evol I

//php substr() — 返回字符串的子串

substr ( string $string , int $start [, int $length ] )

start

如果 start 是非负数,返回的字符串将从 stringstart 位置开始,从 0 开始计算。例如,在字符串 “abcdef” 中,在位置 0 的字符是 “a”,位置 2 的字符串是 “c” 等等。

如果 start 是负数,返回的字符串将从 string 结尾处向前数第 start 个字符开始。

如果 string 的长度小于 start,将返回 FALSE

Example #1 使用负数 start

<?php
$rest = substr("abcdef", -1); // 返回 "f"
$rest = substr("abcdef", -2); // 返回 "ef"
$rest = substr("abcdef", -3, 1); // 返回 "d"
?>

源码:

<?php
$miwen="a1zLbgQsCESEIqRLwuQAyMwLyq2L5VwBxqGA3RQAyumZ0tmMvSGM2ZwB4tws";
//$str为flag $miwen为加密后的字符
function encode($str){
$_o=strrev($str);//倒写字符串
// echo $_o;

for($_0=0;$_0<strlen($_o);$_0++){

$_c=substr($_o,$_0,1); //第$0个字符
$__=ord($_c)+1;//ord()转换为ascii码
$_c=chr($__); //从ascii码返回字符(十进制十六进制八进制

$_=$_.$_c; //acsii+对应的字符
}
return str_rot13(strrev(base64_encode($_)));

//str_rot13()编码或解码,把每一个字母在字母表中向前移动 13 个字母得到。数字和非字母字符保持不变。

//strrev()反转字符串函数
}

highlight_file(__FILE__);
/*
逆向加密算法,解密$miwen就是flag
*/
?>

由源代码可猜出,$str为输入变量(flag),$miwen为加密后的密文

需做的是反向解码,从下向上解

最后输出即为flag

分享到 :
0 人收藏
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

积分:81
帖子:4969
精华:0
期权论坛 期权论坛
发布
内容

下载期权论坛手机APP