Web安全——命令注入漏洞详解

本文涉及的产品
应用实时监控服务-可观测链路OpenTelemetry版,每月50GB免费额度
云原生网关 MSE Higress,422元/月
Serverless 应用引擎免费试用套餐包,4320000 CU,有效期3个月
简介: Web安全——命令注入漏洞详解
点赞后看,养成习惯
喜欢的话 可以点个关注哟
你们的点赞支持对博主们来说很重要哦 !!!

本文将针对以下问题逐条进行解答:

01 命令执行漏洞是什么?

02 为什么会有命令执行漏洞?

03 命令执行漏洞可以用来做什么?

04 我们该如何使用命令执行漏洞?

05 修复方案是什么?

06 什么情况下考虑命令执行漏洞?


image.png



01 命令执行漏洞概念

简单来说, 命令执行漏洞就是黑客能够通过控制外部参数可以达到执行系统命令的效果。

image.png

相较于代码执行漏洞来说,代码执行漏洞是 靠执行脚本代码调用操作系统命令,而命令执行漏洞是直接调用系统命令的漏洞,也叫做os命令执行漏洞。



02 命令执行漏洞产生的原因

原因主要有二:

1.外部参数可控

应用程序调用了执行系统命令的函数,比如服务器程序通过 system、eval、exec等函数直接或者间接地调用 cmd.exe

image.png

黑客能控制这些函数中的参数,比如可以通过浏览器或者其他客户端软件提交一些cmd命令(或者bash命令)至服务器程序。

2.内部拼接命令

服务器将 输入的恶意参数拼接到正常命令中 ,从而执行命令造成攻击



03 命令执行漏洞的危害

黑客如果能够利用命令执行漏洞,那么黑客就可以像电脑用户控制自己电脑一样, 自由地对电脑进行操作,比如开启防火墙、添加路由、开启远程服务等等操作

image.png




04 命令执行漏洞的利用方式
这里以一道CTF题举栗子

1.找到一个可以自己输入参数的页面

如攻防世界中的一道Web题目

image.png

页面场景如下:

image.png


尝试输入本地地址127.0.0.1,观察回显内容

image.png


发现返回内容相似命令行下ping命令返回结果,初步判断可能存在命令执行漏洞

2.利用管道符辅助测试

在场景利用前,我先岔开话题分享一下有关于管道符的一些知识

在操作系统中,“&、|、||”都可以作为命令连接符使用,用户通过浏览器提交执行命令,由于服务器端没有针对执行函数做过滤,导致在没有指定绝对路径的情况下就执行命令。

下面列举
windows系统 linux系统**支持的管道符命令:


windows系统支持的管道符:
示例 用法
a \ b 直接执行命令b
a \ \ b a为假 ,才执行b
a & b a可真可假,若为假则直接执行b
a &&b a为真,b才能执行
linux系统支持的管道符:
示例 用法
a;b 执行完再执行b
a \ b 直接显示b的执行结果
a \ \ b a错,b才执行
a & b a可真可假,若为假则直接执行b
a && b a为真才能执行b

很多时候,我老是忘记符号之间的区别,于是我花心思想了个小技巧记忆,在这里也分享给大家:

|是棍子,单打独斗:
a | b : b是主角,一根棍子的时候不在意a的死活,执行自己的就完事
a || b :b是主角,两根棍子的时候,戾气很重,非要打死a,只有a死了才能执行自己的

image.png


&是拉手,和谐共处:
a & b : b是主角,一次拉手是表面朋友,不管你a是死是活,我都会执行
a & b : b是主角,两次拉手是死党,只有a过得好好的,我才会也执行的好好的

image.png

好,回到这个web场景。我们在第一步的时候判断此处存在系统命令执行漏洞,于是我们使用管道符|进行测试,发现果然可以执行系统命令。

image.png

经过了后续的命令执行,我们很容易的获得了本题的flag

image.png

image.png

总结一下,这道题就是简单考察我们对命令注入漏洞中管道符的使用,较为简单。


05 修复命令执行漏洞漏洞的方案

1.设计者尽可能少设计使用一些命令执行函数,

2.若有必要使用,那么必须对特殊函数做过滤,对用户输入的命令做检查,对客户端提交的变量在进入执行命令前做好过滤和检查等



06 什么情况下考虑命令执行漏洞?

作为一个安全老司机,当我们看到一个可输入参数的位置,心里就要有点痒痒

这时候我们可以尝试使用SQL注入、命令注入试试手,然后查看返回结果,如果返回的内容是命令执行返回的内容,那我们尝试使用管道符辅助测试,比如 127.0.0.1 | whoami

目录
相关文章
|
2月前
|
安全 测试技术 程序员
web渗透-文件包含漏洞
文件包含漏洞源于程序动态包含文件时未严格校验用户输入,导致可加载恶意文件。分为本地和远程包含,常见于PHP,利用伪协议、日志或session文件可实现代码执行,需通过合理过滤和配置防范。
495 79
web渗透-文件包含漏洞
|
13天前
|
安全 Linux iOS开发
Burp Suite Professional 2025.10 发布 - Web 应用安全、测试和扫描
Burp Suite Professional 2025.10 (macOS, Linux, Windows) - Web 应用安全、测试和扫描
155 3
|
2月前
|
存储 安全 前端开发
Web渗透-文件上传漏洞-上篇
文件上传漏洞常见于Web应用,因类型限制不严可致恶意文件执行。本文介绍前端检测、MIME类型、黑名单、.htaccess、空格、双写等多种绕过方式,并结合upload-labs靶场演示利用方法,提升安全防护认知。
179 1
Web渗透-文件上传漏洞-上篇
|
2月前
|
安全 中间件 应用服务中间件
WEB渗透-文件上传漏洞-下篇
本文详解文件上传安全漏洞,涵盖白名单绕过(如00截断、条件竞争)、图片木马制作与利用、以及IIS、Apache、Nginx等常见解析漏洞原理与防御。结合实战案例,深入剖析攻击手法与修复方案。
135 1
|
2月前
|
存储 JavaScript 安全
Web渗透-XSS漏洞深入及xss-labs靶场实战
XSS(跨站脚本攻击)是常见的Web安全漏洞,通过在网页中注入恶意脚本,窃取用户信息或执行非法操作。本文介绍其原理、分类(反射型、存储型、DOM型)、测试方法及xss-labs靶场实战案例,帮助理解与防御XSS攻击。
572 1
Web渗透-XSS漏洞深入及xss-labs靶场实战
|
2月前
|
安全 NoSQL Shell
web渗透-SSRF漏洞及discuz论坛网站测试
SSRF(服务器端请求伪造)是一种安全漏洞,攻击者可诱使服务端发起任意请求,进而探测或攻击内网系统。常用于端口扫描、访问内部服务、读取本地文件等。常见防御包括限制协议、域名和IP,但可通过302跳转、短地址等方式绕过。
155 1
web渗透-SSRF漏洞及discuz论坛网站测试
|
2月前
|
安全 程序员 数据库连接
web渗透-CSRF漏洞
CSRF(跨站请求伪造)是一种常见的Web安全漏洞,攻击者通过伪造用户请求,诱使其在已登录状态下执行非意愿操作。本文介绍CSRF原理、分类(站外与站内)、DVWA靶场搭建及防御措施,如同源策略与Token验证,提升安全防护意识。
275 0
web渗透-CSRF漏洞
|
2月前
|
安全 Linux PHP
Web渗透-命令执行漏洞-及常见靶场检测实战
命令执行漏洞(RCE)指应用程序调用系统命令时,用户可控制输入参数,导致恶意命令被拼接执行,从而危害系统安全。常见于PHP的system、exec等函数。攻击者可通过命令连接符在目标系统上执行任意命令,造成数据泄露或服务瘫痪。漏洞成因包括代码层过滤不严、第三方组件缺陷等。可通过参数过滤、最小权限运行等方式防御。本文还介绍了绕过方式、靶场测试及复现过程。
674 0
|
22天前
|
算法 Java Go
【GoGin】(1)上手Go Gin 基于Go语言开发的Web框架,本文介绍了各种路由的配置信息;包含各场景下请求参数的基本传入接收
gin 框架中采用的路优酷是基于httprouter做的是一个高性能的 HTTP 请求路由器,适用于 Go 语言。它的设计目标是提供高效的路由匹配和低内存占用,特别适合需要高性能和简单路由的应用场景。
131 4
下一篇
开通oss服务