73,【5】BUUCTF WEB [网鼎杯 2020 玄武组]SSRFMe(未解出)

进入靶场

又是代码又是代码又是代码又是代码又是代码又是代码又是代码又是代码又是代码又是代码又是代码又是代码又是代码又是代码

php 复制代码
<?php
// 检查 URL 是否为内部 IP 地址
function check_inner_ip($url)
{
    // 使用正则表达式检查 URL 格式是否以 http、https、gopher 或 dict 开头
    $match_result = preg_match('/^(http|https|gopher|dict)?:\/\/.*(\/)?.*$/',$url);
    // 如果 URL 格式不匹配,终止程序并输出错误信息
    if (!$match_result)
    {
        die('url fomat error');
    }
    try
    {
        // 解析 URL
        $url_parse = parse_url($url);
    }
    catch(Exception $e)
    {
        // 解析 URL 出错时终止程序并输出错误信息
        die('url fomat error');
        return false;
    }
    // 获取 URL 中的主机名
    $hostname = $url_parse['host'];
    // 将主机名解析为 IP 地址
    $ip = gethostbyname($hostname);
    // 将 IP 地址转换为长整型
    $int_ip = ip2long($ip);
    // 检查 IP 地址是否属于内部 IP 地址范围(127.0.0.0/8、10.0.0.0/8、172.16.0.0/12、192.168.0.0/16)
    return ip2long('127.0.0.0')>>24 == $int_ip>>24 || ip2long('10.0.0.0')>>24 == $int_ip>>24 || ip2long('172.16.0.0')>>20 == $int_ip>>20 || ip2long('192.168.0.0')>>16 == $int_ip>>16;
}

// 安全请求 URL 的函数
function safe_request_url($url)
{
    // 检查 URL 是否为内部 IP 地址
    if (check_inner_ip($url))
    {
        // 如果是内部 IP 地址,输出信息
        echo $url.' is inner ip';
    }
    else
    {
        // 使用 cURL 初始化一个会话
        $ch = curl_init();
        // 设置请求的 URL
        curl_setopt($ch, CURLOPT_URL, $url);
        // 设置将响应保存到变量而不是直接输出
        curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
        // 不包含响应头信息
        curl_setopt($ch, CURLOPT_HEADER, 0);
        // 执行 cURL 请求
        $output = curl_exec($ch);
        // 获取请求的信息
        $result_info = curl_getinfo($ch);
        // 如果存在重定向 URL
        if ($result_info['redirect_url'])
        {
            // 递归调用 safe_request_url 处理重定向 URL
            safe_request_url($result_info['redirect_url']);
        }
        // 关闭 cURL 会话
        curl_close($ch);
        // 输出请求结果
        var_dump($output);
    }
}

// 检查是否存在 url 参数
if(isset($_GET['url'])){
    $url = $_GET['url'];
    // 如果 url 参数不为空
    if(!empty($url)){
        // 调用 safe_request_url 函数处理 URL
        safe_request_url($url);
    }
}
else{
    // 如果没有 url 参数,显示当前文件的源代码并进行语法高亮
    highlight_file(__FILE__);
}
// 请在本地访问 hint.php
?>

根据代码信息开始构造url

?url=http://127.0.0.1/hint.php

?url=http://0.0.0.0/hint.php

php 复制代码
<?php
// 检查 REMOTE_ADDR 是否为 127.0.0.1,如果是,则显示当前文件的源代码并进行语法高亮
if($_SERVER['REMOTE_ADDR']==="127.0.0.1"){
    // 使用 highlight_file 函数将当前文件的源代码高亮显示
    highlight_file(__FILE__);
}

// 检查是否通过 POST 方法提交了名为 file 的参数
if(isset($_POST['file'])){
    // 使用 file_put_contents 函数将一段 PHP 代码写入到 $_POST['file'] 指定的文件中
    // 写入的内容为:<?php echo 'redispass is root';exit(); 加上 $_POST['file'] 的内容
    file_put_contents($_POST['file'],"<?php echo 'redispass is root';exit();".$_POST['file']);
}

得到redis密码为root

可是redis是啥啊

https://www.freebuf.com/articles/web/293030.html

先看看上面这篇文章吧,我要好好理解理解

相关推荐
Esaka_Forever13 分钟前
few‑shot learning(少样本学习)
人工智能·学习
中屹指纹浏览器1 小时前
2026指纹浏览器行为指纹对抗技术详解:从算法识别到真人模拟全方案
经验分享·笔记
川石课堂软件测试1 小时前
零基础小白如何学习自动化测试
python·功能测试·学习·测试工具·jmeter·压力测试·harmonyos
2301_809051141 小时前
Linux 数据库开发 学习笔记
笔记·学习·数据库开发
爱喝水的鱼丶2 小时前
SAP-ABAP:SAP 简单报表输出开发系列(共6篇)第三篇:SAP ALV 报表样式定制:字段布局与交互功能配置
服务器·开发语言·学习·交互·sap·abap
很楠爱上2 小时前
Node.js 模块化学习笔记
笔记·学习·node.js
mnasd2 小时前
RockyLinux 9.5 部署 Kubernetes1.35 集群
笔记
毕竟是shy哥2 小时前
CLIP:从自然语言监督中学习可迁移的视觉模型
学习
川石课堂软件测试2 小时前
作为一名测试工程师如何学习Kubernetes(k8s)技能
学习·测试工具·容器·职场和发展·kubernetes·测试用例·harmonyos
tryqaaa_2 小时前
学习日志(五)【php反序列化全加例题】【pop链,字符逃逸,session,伪协议】
android·学习·php·web·pop·session