当前位置: 首页 > article >正文

pwn刷题记录

NSS-[CISCN 2023 初赛]funcanary【canary】NSSCTF | 在线CTF平台下载附件,直接去checksec文件,查看文件二进制保护机制再通过file命令查看文件的信息ida64打开,首先查看main函数void __fastcall __noreturn main(__int64 a1, char **a2, char **a3) { __pid_t v3; // [rsp+Ch] [rbp-4h] sub_1243(a1, a2, a3); while ( 1 ) { v3 = fork(); if ( v3 0 ) break; if ( v3 ) { wait(0LL); } else { puts("welcome"); sub_128A(); puts("have fun"); } } puts("fork error"); exit(0); }fork函数:fork()用于创建一个子进程,我们在shell下执行一个命令其实也是通过fork()实现的,fork()是Linux下最基本的一个系统调用。fork()最大的特点就是一次调用,两次返回,两次返回主要是区分父子进程,因为fork()之后将出现两个进程,所以有两个返回值,父进程返回子进程ID,子进程返回0。通过复制的方式创建一个进程,被创建的进程称为子进程,调用进程称为父进程,复制的子进程是从父进程fork()调用后面的语句开始执行的。这也就是说fork()函数,将调用自己前的复制了下来,再创建了一个子进程。子进程和父进程在开始执行时是一模一样的,但是它们的执行状态可以独立进行改变。进程ID:进程ID(PID)是操作系统分配给每个进程的唯一标识符。在同一时刻,每个运行中的进程都有一个唯一的PID。当一个进程被创建时,操作系统会为其分配一个唯一的PID。PID 通常是一个正整数,系统会在进程终止后回收其PID,并可能在未来为新的进程重新分配该PID。通过shift+f12,我们可以看到一个特殊的字符串,这或许是一个后门在main函数中,看到了一个fork函数,和一个sub_128A()函数因为有fork函数,这个值得我们好好利用。f前文提到fork函数将复制出一个子进程,包括但不限于代码段、数据段、堆和栈。也就是说子进程的最初状态与父进程完全一致,如此便可以知道:子父进程的canary完全相同。当程序存在fork函数并触发canary时,__ stack_chk_fail函数只能关闭fork函数所建立的进程,不会让主进程退出,所以当存在大量调用fork函数时,我们可以利用它来一字节一字节的泄露。查看一下sub_128A,调用了read函数,又存在地址0x28,这是经典的金丝雀v2的值通过__readfsqword(0x28u)读取,这是从线程信息块(TIB)中读取堆叠

相关文章:

pwn刷题记录

NSS-[CISCN 2023 初赛]funcanary【canary】 NSSCTF | 在线CTF平台 下载附件,直接去checksec文件,查看文件二进制保护机制再通过file命令查看文件的信息 ida64打开,首先查看main函数 void __fastcall __noreturn main(__int64 a1, char **a2, char **a3) {__pid_t v3; //…...

git管理github上的repository(二)

本文章主要介绍如何使用git管理一个project,并更新到github上1. 创建github仓库登录github账户;在右上角点击“”号,选择“New repository”;填写仓库名称、描述(可选),选择是否为公共或私有仓库…...

ubuntu vnc 问题汇总

第一部分:使用虚拟显示管理器 如何让树莓派不连接显示器,也能在windows上用vnc访问? 如题配置完成后,树莓派就可以在不连接物理显示器的情况下通过VNC远程访问了。 1. 安装必要的包 sudo apt install xserver-xorg-video-dumm…...

Camera:实时监控与数据交互的智能设备服务

Camera:实时监控与数据交互的智能设备服务 【免费下载链接】Camera The EdgeX Camera Device Service is developed to control/communicate ONVIF-compliant cameras accessible via http in an EdgeX deployment 项目地址: https://gitcode.com/gh_mirrors/came…...

AnOpc:轻松实现OPC操作的利器

AnOpc:轻松实现OPC操作的利器 【免费下载链接】AnOpc An Opc Library and a command line to perform OPC operations with ease and transparency among different protocols. Currently supports synchronous operation over UA and DA protocols. 项目地址: ht…...

python实现鸟类识别系统实现方案

鸟类识别系统实现方案 1. 系统概述 本系统使用两种机器学习模型(线性判别分析和卷积神经网络)实现鸟类识别,支持识别10种常见鸟类。系统包含数据预处理、特征提取、模型训练和预测评估等完整流程。 2. 数据集准备 使用CUB-200-2011鸟类数据集子集(10类),每类包含60张…...

Kong/mashape-oauth项目中的OAuth协议详解

Kong/mashape-oauth项目中的OAuth协议详解 【免费下载链接】mashape-oauth OAuth Modules for Node.js - Supporting RSA, HMAC, PLAINTEXT, 2,3-Legged, 1.0a, Echo, XAuth, and 2.0 项目地址: https://gitcode.com/gh_mirrors/ma/mashape-oauth 前言 OAuth协议是现代…...

URLImage源码解读:如何设计高效的图片缓存系统

URLImage源码解读:如何设计高效的图片缓存系统 【免费下载链接】url-image AsyncImage before iOS 15. Lightweight, pure SwiftUI Image view, that displays an image downloaded from URL, with auxiliary views and local cache. 项目地址: https://gitcode.c…...

Laravel Sweet Alert与SweetAlert2深度整合:功能扩展与最佳实践

Laravel Sweet Alert与SweetAlert2深度整合:功能扩展与最佳实践 【免费下载链接】sweet-alert A BEAUTIFUL, RESPONSIVE, CUSTOMIZABLE, ACCESSIBLE (WAI-ARIA) REPLACEMENT FOR JAVASCRIPTS POPUP BOXES FOR LARAVEL 项目地址: https://gitcode.com/gh_mirrors/s…...

LNbits资金来源配置:支持多种闪电网络后端的灵活选择

LNbits资金来源配置:支持多种闪电网络后端的灵活选择 【免费下载链接】lnbits LNbits, free and open-source Lightning wallet and accounts system. 项目地址: https://gitcode.com/gh_mirrors/ln/lnbits LNbits是一款免费开源的闪电网络钱包和账户系统&am…...

SimpleLightbox入门教程:从安装到实现响应式图片画廊的5个步骤

SimpleLightbox入门教程:从安装到实现响应式图片画廊的5个步骤 【免费下载链接】simplelightbox Touch-friendly image lightbox for mobile and desktop 项目地址: https://gitcode.com/gh_mirrors/si/simplelightbox SimpleLightbox是一款轻量级且功能强大…...

制作专业级CHM文档:cppreference2mshelp关键词索引与目录生成技巧

制作专业级CHM文档:cppreference2mshelp关键词索引与目录生成技巧 【免费下载链接】cppreference2mshelp cppreference.com html archive converter to microsoft help (for Visual Studio 2012) and chm help (for Windows) 项目地址: https://gitcode.com/gh_m…...

FALCONN性能调优指南:如何为不同数据集选择最佳参数

FALCONN性能调优指南:如何为不同数据集选择最佳参数 【免费下载链接】FALCONN FAst Lookups of Cosine and Other Nearest Neighbors (based on fast locality-sensitive hashing) 项目地址: https://gitcode.com/gh_mirrors/fa/FALCONN FALCONN(…...

Patching插件架构深度剖析:Keystone引擎如何赋能二进制修补

Patching插件架构深度剖析:Keystone引擎如何赋能二进制修补 【免费下载链接】patching An Interactive Binary Patching Plugin for IDA Pro 项目地址: https://gitcode.com/gh_mirrors/pa/patching Patching是一款专为IDA Pro设计的交互式二进制修补插件&am…...

Flyimg高级配置指南:自定义ImageMagick参数实现专业级图片优化

Flyimg高级配置指南:自定义ImageMagick参数实现专业级图片优化 【免费下载链接】flyimg Dockerized application to resize and crop images on the fly. Get optimised images with AVIF, WebP, MozJPEG or PNG using ImageMagick, with an efficient caching syst…...

Secator常见问题解决:工具安装失败、任务卡死与性能优化的实用技巧

Secator常见问题解决:工具安装失败、任务卡死与性能优化的实用技巧 【免费下载链接】secator secator - the pentesters swiss knife 项目地址: https://gitcode.com/gh_mirrors/se/secator Secator作为渗透测试人员的瑞士军刀,集成了多种安全测试…...

告别配置噩梦:Archon环境检查神器帮你秒定位问题

告别配置噩梦:Archon环境检查神器帮你秒定位问题 【免费下载链接】Archon Archon is an AI agent that is able to create other AI agents using an advanced agentic coding workflow and framework knowledge base to unlock a new frontier of automated agents…...

一文读懂:银行接口对接中的P10文件、证书与安全通信

在与银行进行API接口对接时,安全是头等大事。您一定会遇到“提供P10文件”这个要求。本文将从零开始,清晰解释P10是什么、为什么需要它、以及它如何在整个安全链条中发挥作用。一、P10文件是什么?P10文件,正式名称为证书签名请求&…...

使用SSHamble检测弱密钥:badkeys集成与实战案例

使用SSHamble检测弱密钥:badkeys集成与实战案例 【免费下载链接】sshamble SSHamble: Unexpected Exposures in SSH 项目地址: https://gitcode.com/gh_mirrors/ss/sshamble SSHamble是一款专注于SSH安全检测的工具,能够帮助用户发现SSH服务中存在…...

性能优化与最佳实践:避免常见陷阱

性能优化与最佳实践:避免常见陷阱 【免费下载链接】android-floating-action-button Floating Action Button for Android based on Material Design specification 项目地址: https://gitcode.com/gh_mirrors/an/android-floating-action-button 本文详细分…...

扩展与集成:Gradle依赖与ProGuard配置

扩展与集成:Gradle依赖与ProGuard配置 【免费下载链接】android-floating-action-button 项目地址: https://gitcode.com/gh_mirrors/se/sell-android-floating-action-button 本文详细介绍了Android FloatingActionButton库的Gradle依赖配置、版本管理策略…...

知识图谱生成工具knowledge_graph:如何将任意文本转化为可视化知识网络

知识图谱生成工具knowledge_graph:如何将任意文本转化为可视化知识网络 【免费下载链接】knowledge_graph Convert any text to a graph of knowledge. This can be used for Graph Augmented Generation or Knowledge Graph based QnA 项目地址: https://gitcode…...

Atmosphere核心组件解析:Broadcaster与Transport如何实现跨浏览器实时通信

Atmosphere核心组件解析:Broadcaster与Transport如何实现跨浏览器实时通信 【免费下载链接】atmosphere Event Driven WebSockets Framework with Cross-Browser Fallbacks 项目地址: https://gitcode.com/gh_mirrors/atm/atmosphere Atmosphere作为一款强大…...

X-CMD安全沙箱使用教程:在隔离环境中安全运行第三方工具

X-CMD安全沙箱使用教程:在隔离环境中安全运行第三方工具 【免费下载链接】x-cmd Opensource lightweight posix script for tools (500) management and classic command extensions 项目地址: https://gitcode.com/gh_mirrors/xc/x-cmd X-CMD(Gi…...

optimize-js实战教程:如何在Webpack和Browserify中集成使用

optimize-js实战教程:如何在Webpack和Browserify中集成使用 【免费下载链接】optimize-js Optimize a JS file for faster parsing (UNMAINTAINED) 项目地址: https://gitcode.com/gh_mirrors/op/optimize-js optimize-js是一个强大的JavaScript优化工具&…...

7大核心技术揭秘:数据科学如何彻底变革农业精准种植与产量预测

7大核心技术揭秘:数据科学如何彻底变革农业精准种植与产量预测 【免费下载链接】awesome-datascience awesome-datascience: 是一个包含各种数据科学资源、工具和实践的汇总列表。适合数据科学家、分析师和开发者查找和学习数据科学的知识和技术。 项目地址: http…...

复购率不理想如何用产品线组合提升长期价值

从“一次性交易”到“终身伙伴”:产品线组合的破局之道在竞争日益激烈的商业环境中,许多企业都面临一个共同的困境:客户首次购买后,便如石沉大海,复购率持续低迷。这不仅是收入的损失,更是品牌与用户关系脆…...

5分钟上手Atmosphere:快速搭建你的第一个WebSocket聊天应用

5分钟上手Atmosphere:快速搭建你的第一个WebSocket聊天应用 【免费下载链接】atmosphere Event Driven WebSockets Framework with Cross-Browser Fallbacks 项目地址: https://gitcode.com/gh_mirrors/atm/atmosphere Atmosphere是一款强大的Event Driven W…...

pinyin高级功能:分词模式与姓名模式的实战应用

pinyin高级功能:分词模式与姓名模式的实战应用 【免费下载链接】pinyin :cn: 汉字拼音 ➜ hn z pīn yīn 项目地址: https://gitcode.com/gh_mirrors/pi/pinyin pinyin是一款功能强大的汉字拼音转换工具,能够将中文字符精准转换为拼音&#xff0…...

评价关键词出现负面趋势如何做快速定位与修复

在数字时代,品牌声誉如同空气,平时不易察觉,一旦恶化却足以令人窒息。当监测系统亮起红灯,显示某些核心评价关键词的负面声量正悄然攀升时,一场与时间的赛跑便已开始。这不仅关乎一次危机的化解,更是一次审…...