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

command injection命令注入

命令注入

是指程序中有调用系统命令的部分,例如输入ip,程序调用系统命令ping这个ip。如果在ip后面加一个&&、&、|、||命令拼接符号再跟上自己需要执行的系统命令

在ping设备的输入框中ip后面加上&ifconfig,或者其他命令

 222.222.221.138&ifconfig

和文件上传漏洞对比

相同点

相同的地方是都是根据程序调用系统命令

不同点

命令注入是程序调用系统命令,在参数没有约束的情况下,在参数后加上需要执行的系统命令。这个限制在于程序不一定提供这种调用系统命令的功能。

文件上传漏洞是自己手动上传一个执行系统命令的页面,然后访问这个页面,把命令以参数的形式传给页面执行。

上图中在文件上传漏洞同样可以达到一样的效果

防护

参数过滤

白名单保护

如果命令的参数是有特征性的建议使用白名单对输入的参数进行保护

比如允许[a-z][A-Z][0-9] _- 等有限的字符

 黑名单保护

|;&$><`\! 可以将这些字符直接作为黑名单过滤

\t\n\r\f \u0000 这些字符需要作为黑名单过滤,特别是空字符截断 \u0000 (这个在JVM6里是没有保护)

 

转载于:https://www.cnblogs.com/aeolian/p/11051361.html

相关文章:

  • java 发送邮件
  • apt-fast
  • Excel导出通用操作方式
  • 我感恩
  • 如何清除Exchange2010邮件日志
  • 人类的殒落与扬升
  • 304441事务管理与并发控制
  • 【412】Linux 系统编译 C 程序
  • 那些年我们一起遗忘的位运算!
  • Pots bfs()记录每一种状态,直到求出最优值
  • .Net Remoting(分离服务程序实现) - Part.3
  • ssh架构简单解释和vo po解释
  • [NOIP2018 PJ T4]对称二叉树
  • 移动互联网时代的人才管理新思维之学习笔记
  • Codeforces Round #159 (Div. 2) B. Playing Cubes
  • #Java异常处理
  • 2017-08-04 前端日报
  • CNN 在图像分割中的简史:从 R-CNN 到 Mask R-CNN
  • ERLANG 网工修炼笔记 ---- UDP
  • golang 发送GET和POST示例
  • jquery ajax学习笔记
  • Mysql5.6主从复制
  • Promise面试题2实现异步串行执行
  • TypeScript实现数据结构(一)栈,队列,链表
  • Vue组件定义
  • 从零开始的webpack生活-0x009:FilesLoader装载文件
  • 前端js -- this指向总结。
  • 前端知识点整理(待续)
  • 收藏好这篇,别再只说“数据劫持”了
  • 微信公众号开发小记——5.python微信红包
  • 项目实战-Api的解决方案
  • 在weex里面使用chart图表
  • 1.Ext JS 建立web开发工程
  • AI又要和人类“对打”,Deepmind宣布《星战Ⅱ》即将开始 ...
  • 关于Android全面屏虚拟导航栏的适配总结
  • 继 XDL 之后,阿里妈妈开源大规模分布式图表征学习框架 Euler ...
  • ​LeetCode解法汇总1276. 不浪费原料的汉堡制作方案
  • $.ajax()参数及用法
  • (32位汇编 五)mov/add/sub/and/or/xor/not
  • (42)STM32——LCD显示屏实验笔记
  • (备忘)Java Map 遍历
  • (读书笔记)Javascript高级程序设计---ECMAScript基础
  • (二)Pytorch快速搭建神经网络模型实现气温预测回归(代码+详细注解)
  • (二)学习JVM —— 垃圾回收机制
  • (附源码)spring boot校园拼车微信小程序 毕业设计 091617
  • (论文阅读40-45)图像描述1
  • (免费领源码)python#django#mysql校园校园宿舍管理系统84831-计算机毕业设计项目选题推荐
  • (十五)Flask覆写wsgi_app函数实现自定义中间件
  • (转)linux下的时间函数使用
  • (转)利用PHP的debug_backtrace函数,实现PHP文件权限管理、动态加载 【反射】...
  • (转载)虚幻引擎3--【UnrealScript教程】章节一:20.location和rotation
  • ***检测工具之RKHunter AIDE
  • .bat批处理(二):%0 %1——给批处理脚本传递参数
  • .gitignore文件---让git自动忽略指定文件
  • .NET Micro Framework 4.2 beta 源码探析