命令注入漏洞原因以及危害

命令注入

原因

当应用需要调用一些外部程序时会用到一些系统命令的函数。应用在调用这些函数执行系统命令的时候,如果将用户的输入作为系统命令的参数拼接到命令行中,在没有过滤用户的输入情况下,会造成命令执行漏洞。

漏洞危害

1、继承Web 服务器程序权限,去执行系统命令

2、继承Web 服务器权限,读取文件

3、反弹Shell

4、控制整个网站

5、控制整个服务器

相关函数和语言结构

system():能够将字符串作为OS命令执行,自带输出功能。

<?php
if(isset($__GET('cmd'))){
	echo "<pre>";
	system($__GET['cmd']);
}else{
	echo "?cmd=ipconfig";
}
?>

exec():能够将字符串作为OS命令执行,需要输出执行结果。返回结果是有限的

<?php
if(isset($__GET['cmd'])){
	echo "<pre>";
	print exec($__GET['cmd']);
}else{
	echo "?cmd=whoami";
}
?>

  • 1
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值