pwn题解第一道

本文介绍了作者在pwnable.kr网站尝试第一道pwn题目时的经历。通过连接并查看文件,作者发现无法直接打开flag文件,但通过分析fd.c代码和理解Linux中的文件描述符(file descriptor),他找到了解决方案。利用文件描述符为0时系统会创建新文件的特性,作者成功将内容改为LETMEWIN,获得了flag。此过程有助于加深对Linux文件系统的理解。
摘要由CSDN通过智能技术生成

今天听说了一个网站pwnable.kr。很适合初学者,就试着做了一道题目。

第一道题目,按照网页上给的链接,使用putty链接工具联入。

输入ls命令查看文件内容。


很开心的看到了flag文件,于是直接打开,果然不出所料,我是没有权限打开的。然后查看了一下fd.c的代码。

#include <stdio.h>
#include <stdlib.h>
#include <string.h>
char buf[32];
int main(int argc, char* argv[], char* envp[]){
        if(argc<2){
                printf("pass argv[1] a number\n");
                return 0;
        }
        int fd = atoi( argv[1] ) - 0x1234;
        int len = 0;
        len = read(fd, buf, 32);
        if(!strcmp("LETMEWIN\n", buf)){
                printf("good job :)\n");
                system("/bin/cat flag");
              
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值