博客
关于我
checksec未完待续~
阅读量:351 次
发布时间:2019-03-04

本文共 1186 字,大约阅读时间需要 3 分钟。

checksec是一个脚本软件,也就是用脚本写的一个文件,不到2000行,可用来学习shell。

源码参见
下载方法之一为
wget

checksec用来干什么?

用来检查可执行文件属性,例如PIE, RELRO, PaX, Canaries, ASLR, Fortify Source

PIE是什么意思?

(PIC:Position Independnet Code位置无关代码)
position independent executable

RELRO是什么意思?

Built with RELRO
RELRO stands for RELocation Read-Only, it is a mitigation technique to harden data sections of an ELF/process.

Pax是什么意思?

Stack Canary
ASLR是什么意思?

checksec使用方法

这里写图片描述

checksec –file /usr/sbin/sshd

这里写图片描述

源码解读:

ubuntu测试important!!!!
self.assertShellExitEquals()太重要了

  • def assertShellOutputEquals(self, text, args, stdin=None,
    stdout=subprocess.PIPE, stderr=subprocess.STDOUT, msg=”“, invert=False,
    expected=None):
  • ”’Test a shell command matches a specific output”’
  • rc, report, out = self._testlib_shell_cmd(args, stdin=stdin,
    stdout=stdout, stderr=stderr)
  • result = ‘Got exit code %d. Looking for exact text “%s” (%s)\n’ % (rc,
    text, ” “.join(args))
  • if not invert:
  • self.assertEquals(text, out, msg + result + report)
  • else:
  • self.assertNotEquals(text, out, msg + result + report)
  • if expected != None:
  • result = ‘Got exit code %d. Expected %d (%s)\n’ % (rc, expected, ”
    “.join(args))
  • self.assertEquals(rc, expected, msg + result + report)

现代Linux操作系统的栈溢出(上)

你可能感兴趣的文章
WAP短信格式解析及在Linux下用C语言实现
查看>>
nagios+cacti整合
查看>>
Nagios介绍
查看>>
nagios利用NSCient监控远程window主机
查看>>
nagios安装文档
查看>>
nagios服务端安装
查看>>
Nagios自定义监控脚本
查看>>
name_save matlab
查看>>
Nami 项目使用教程
查看>>
Nancy之基于Nancy.Hosting.Aspnet的小Demo
查看>>
NAND NOR FLASH闪存产品概述
查看>>
nano 编辑
查看>>
nanoGPT 教程:从零开始训练语言模型
查看>>
NASA网站曝严重漏洞,或将沦为黑客钓鱼网站?
查看>>
Nash:轻量级、安全且可靠的脚本语言
查看>>
NAS、SAN和DAS的区别
查看>>
NAS个人云存储服务器搭建
查看>>
NAS服务器有哪些优势
查看>>
NAT PAT故障排除实战指南:从原理到技巧的深度探索
查看>>
nat 网卡间数据包转发_你是不是从来没有了解过光纤网卡,它跟普通网卡有什么区别?...
查看>>