干货 | 命令执行漏洞和代码执行漏洞详解

远程命令执行(rce)和代码执行漏洞之间的区别如下:

代码执行实际上是调用服务器网站的代码进行执行,而命令执行则是调用操作系统命令进行执行。

一、命令执行漏洞

1、什么是命令执行?

命令执行(Remote Command Execution, RCE)指的是Web应用的脚本代码在执行命令时由于过滤不严,从而注入一段攻击者能够控制的代码,在服务器上以Web服务的后台权限远程执行恶意指令。

成因:

代码层过滤不严系统的漏洞造成命令注入调用的第三方组件存在代码执行漏洞

常见的命令执行函数:

PHP: exec、shell_exec、system、passthru、popen、proc_open等ASP.NET: System.Diagnostics.Start.Process、System.Diagnostics.Start.ProcessStartInfo等Java: java.lang.runtime.Runtime.getRuntime、java.lang.runtime.Runtime.exec等

2、常用命令执行函数

(1)system

该函数会把执行结果输出,并把输出结果的最后一行作为字符串返回,如果执行失败则返回false。这个函数也最为常用。


(2)exec

不输出结果,返回执行结果的最后一行,可以使用output进行输出。


(3)passthru

此函数只调用命令,并把运行结果原样地直接输出,没有返回值。


(4)shell_exec

不输出结果,返回执行结果,使用反引号(“)时调用的就是此函数。


(5)ob_start

此函数将打开输出缓冲,当输出缓冲激活后,脚本将不会输出内容(除http标头外),相反需要输出的内容被存储在内部缓冲区中。内部缓冲区的内容可以用 ob_get_contents() 函数复制到一个字符串变量中。想要输出存储在内部缓冲区中的内容,可以使用 ob_end_flush() 函数。另外,使用 ob_end_clean() 函数会静默丢弃掉缓冲区的内容。


3、命令连接符

Windows和Linux都支持的命令连接符:

cmd1 | cmd2:只执行cmd2cmd1 || cmd2:只有当cmd1执行失败后,cmd2才被执行cmd1 & cmd2:先执行cmd1,不管是否成功,都会执行cmd2cmd1 && cmd2:先执行cmd1,cmd1执行成功后才执行cmd2,否则不执行cmd2

Linux还支持分号;

cmd1 ; cmd2:按顺序依次执行,先执行cmd1再执行cmd2

二、代码执行漏洞

1、什么是代码执行?

代码执行漏洞是由于服务器对危险函数过滤不严,导致用户输入的一些字符串可以被转换成代码来执行,从而造成代码执行漏洞。

成因:

用户能够控制函数输入存在可执行代码的危险函数

常见代码执行函数:

PHP: eval、assert、preg_replace()、+/e模式(PHP版本${}执行代码中间的php代码将会被解析)

<?php ${

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/455736.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年11月8日 01:19:18
下一篇 2025年11月8日 01:20:21

相关推荐

  • dev c++ 如何设置编译选项

    在 dev-c++++ 中设置编译选项的方法是:1. 点击“工具”菜单,选择“编译器选项”。2. 在“编译器”选项卡中的“附加的编译器选项”字段输入选项。编译选项通过 gcc 实现,可以优化代码、生成调试信息等,需权衡选项的优缺点。 引言 在编程世界中,编译选项就像是调味料,能让你的代码变得更加美味…

    2025年12月18日
    000
  • dev c++ 怎么添加外部库

    在 dev-c++++ 中添加外部库的步骤如下:1. 下载库文件:从官方网站下载适合系统的库文件,如 libcurl。2. 添加头文件:在代码中包含头文件并将头文件目录添加到编译器搜索路径中。3. 添加库文件:在代码中链接库文件并将库文件目录添加到链接器搜索路径中。4. 编写和编译代码:使用库编写代…

    2025年12月18日
    000
  • 如何在 sublime text 中运行 c++ 代码

    在 #%#$#%@%@%$#%$#%#%#$%@_348c++880664f2e1458b899ced2a3518e6 text 中运行 c++ 代码需要配置构建系统。1. 安装 c++ 编译器(如 mingw、xcode 或 gcc)。2. 创建并保存 c++.sublime-build 文件,定…

    2025年12月18日
    000
  • Dev-C++ 版的问题

    dev-c++++ 4.9.9.2 编译错误及解决方案 在 Windows 11 系统使用 Dev-C++ 4.9.9.2 编译程序时,编译器记录窗格可能会显示以下错误信息: gcc.exe: internal error: aborted (program collect2)please subm…

    2025年12月18日
    000
  • dev c++ 怎么更改主题颜色

    要在 dev-c++++ 中更改主题颜色,需编辑 default.ini 文件并修改颜色值。1. 找到 default.ini 文件,通常在安装目录下。2. 修改 [colors] 下的 rgb 或十六进制值,如 background=000000 设为黑色。3. 保存文件并重启 dev-c++ 使…

    2025年12月18日
    000
  • vs 怎么设置代码自动补全

    在 visual studio 中设置代码自动补全功能可以通过以下步骤实现:1) 确保安装最新版本的 vs;2) 进入“选项”菜单,选择“文本编辑器”,然后选择编程语言,调整“intellisense”设置,如启用“自动导入命名空间”和调整“过滤列表”;3) 使用快捷键如 ctrl + space …

    2025年12月18日
    000
  • C语言从0开始

    C语言学习起步可能略显困难,但掌握正确方法后,您将快速掌握基础并逐步精通。本指南将引导您循序渐进地学习C语言核心概念,从基础知识到高级主题。 目录 C语言基础与数据类型用户输入条件表达式简写switch语句C语言数组嵌套循环C语言函数结构体指针 C语言基础与数据类型 C程序遵循标准结构,并使用多种数…

    2025年12月18日
    000
  • 堆栈框架和功能调用:如何创建CPU开销

    我痴迷于计算机科学与软件工程的方方面面,尤其对底层编程情有独钟。探索软件与硬件的交互机制,分析其边界行为,着实令人着迷。即使在高级应用编程中,这些知识也能帮助调试和解决问题,例如堆栈内存的运用。理解堆栈内存的工作原理,特别是与硬件交互时,对于避免和调试问题至关重要。 本文将探讨程序中频繁的函数调用如…

    2025年12月18日
    000
  • 分配C中的字符串

    让我们来分析一下这两段C语言代码,看看为什么它们的行为差异如此之大。 代码示例一: #include <stdio.h>int main(void){ char *string = "wello, world!"; string[0] = ‘h’; puts(stri…

    2025年12月18日
    000
  • libv是两个

    我开发了一个名为Lua-Libuv的项目,并乐于分享我的经验。项目初衷是探索如何利用Libuv(一个用C语言编写的异步I/O库)构建简单的HTTP服务器,而无需深入掌握C语言。 借助ChatGPT的辅助,我完成了HTTP.C的基础代码。在处理持久连接时,我成功实现了在适当的时机关闭连接并释放资源。起…

    好文分享 2025年12月18日
    000
  • 网络服务安装

    推介会: 本 SAE(业务学习情况)项目旨在开发一个基于客户端-服务器架构的实时“CAT”网络讨论应用程序。该应用允许多个客户端连接到中央服务器并进行实时通信。下图概述了套接字功能: 资源配置: 编程语言:C 语言版本控制:使用分布式 Github 进行代码共享开发环境:Visual Studio …

    2025年12月18日
    000
  • c语言函数声明和调用的区别 什么是c语言函数声明和调用

    C语言函数声明告知编译器函数的存在和参数类型,而调用执行函数代码。函数声明中参数类型必须明确,声明和定义中的参数类型必须匹配。参数传递以值传递方式进行,修改函数内参数值不影响函数外参数值。返回值类型应与声明一致,忽略返回值或不匹配会导致错误。为优化性能,避免传递大型数据结构或过多调用函数,并遵循良好…

    2025年12月18日
    000
  • c语言函数的定义和调用规则是什么

    C语言函数是可重复使用的代码块,就像乐高积木一样,可用于构建复杂程序。它们包含函数定义(返回类型、函数名、参数列表、函数体)和函数调用(使用预先定义的代码块)。参数传递有值传递和指针传递两种方式,取决于需求。函数原型声明在调用函数前提前定义其接口,有助于避免错误。函数的核心价值在于代码重用和模块化,…

    2025年12月18日
    000
  • c语言函数的嵌套调用和递归调用区别是什么

    函数嵌套调用类似于乐队演奏,多个函数有序调用,清晰易懂。递归调用像回声,函数自调用,直到满足终止条件,功能强大但容易出错,需注意设置终止条件和栈溢出风险。 函数的嵌套与递归:一场代码的二重奏 很多初学者会把函数嵌套调用和递归调用搞混,觉得它们长得差不多,其实不然。这就好比小提琴和钢琴,虽然都是乐器,…

    2025年12月18日
    000
  • c语言函数的定义包括哪两个?有什么区别?

    C语言函数定义包括函数头和函数体,其中函数头定义了函数的返回类型、函数名和参数类型,而函数体则包含了函数的具体实现。参数传递方式(值传递或地址传递)会影响函数内部修改参数对调用函数变量的影响。函数体应遵循单一职责、代码简洁、错误处理和性能优化原则。理解编译器对函数定义的处理过程有助于编写更可靠的代码…

    2025年12月18日
    000
  • c语言函数的嵌套调用和递归调用

    函数嵌套调用类似套娃,函数A调用函数B,而B又可能调用C;递归调用则如一面镜子,函数自身调用自身。嵌套调用提高可读性,但层数过多会降低理解难度;递归调用适用于自相似问题,但存在栈溢出风险。性能上,嵌套调用优于递归调用,但对于特定问题,递归代码更简洁。谨慎使用嵌套和递归,避免代码复杂化,追求简洁优雅的…

    2025年12月18日
    000
  • c语言函数的声明应该写在哪里

    C语言函数声明的最佳放置位置取决于代码组织和工程规模。将函数声明放在头文件(.h)中是最佳实践,它提供模块化、代码复用和编译效率。头文件中只能包含函数声明,而函数定义则在源文件中。避免重复包含和声明与定义不一致等潜在陷阱,并养成良好的代码组织习惯,有助于提升代码质量和开发效率。 C语言函数声明:位置…

    2025年12月18日
    000
  • c语言函数声明和调用的区别

    函数声明明确函数接口,包括返回类型、函数名和参数列表;函数调用使用已声明的函数,传递参数并接收返回值。声明不仅供编译时类型检查,还增强代码模块化和可读性。函数调用采用值传递,指针参数除外;数组参数传递首地址。编译器查找函数定义并执行,包括地址查找、参数传递和返回值处理。谨慎声明和使用参数类型,避免指…

    2025年12月18日
    000
  • c语言和c的区别 c语言和c有哪些区别

    C和C++之间的区别不仅在于面向对象编程。C++还引入了命名空间、引用、异常处理、模板和STL等特性,使其更加灵活和强大,但学习难度也更高。选择哪种语言取决于项目需求:C适用于高性能系统软件或嵌入式系统开发,而C++则适用于大型或复杂的应用程序开发。无论选择哪种语言,循序渐进的学习和实践至关重要。 …

    2025年12月18日
    000
  • 嵌入式c语言和c语言区别 嵌入式c语言和c语言异同分析

    嵌入式C与标准C的区别在于:底层操作:嵌入式C直接操作硬件,而标准C主要通过操作系统接口交互。内存管理:嵌入式C注重节约内存,谨慎使用动态分配。库函数:嵌入式C包含必要的库函数,精简高效。可移植性:嵌入式C可移植性较差,需根据硬件平台修改代码。 嵌入式C与标准C:骨子里都流淌着C的血液,却有着不同的…

    2025年12月18日
    000

发表回复

登录后才能评论
关注微信