有些应用是通过后台执行OS 命令实现的(如shell), 像导出tech-support文件. 如果又使用了用户输入作为命令的一部分就很容易出现命令注入(command injection)漏洞。
Ways of injecting OS commands
分割字符
- &
- &&
- |
- ||
unix独有分割字符
- ;
- 0x0a or \n
unix inline execution
- `
- $(
python注入
“\r\n”都会作为python的换行符:
result = []
with self._storage_file.open(encoding='utf-8') as input_stream:
for line in input_stream:
# Remove trailing newline so it won't become part of the value.
entry_key, entry_value = line.rstrip().split(':', 1)
if entry_key == key:
result.append(entry_value)
return result
如果内容中有\r
也会被当作换行符处理。
how to prevent
The most effective way to prevent OS command injection vulnerabilities is to never call out to OS commands from application-layer code. In almost all cases, there are different ways to implement the required functionality using safer platform APIs.
If you have to call out to OS commands with user-supplied input, then you must perform strong input validation. Some examples of effective validation include:
- Validating against a whitelist of permitted values.
- Validating that the input is a number.
- Validating that the input contains only alphanumeric characters, no other syntax or whitespace.
Never attempt to sanitize input by escaping shell metacharacters. In practice, this is just too error-prone and vulnerable to being bypassed by a skilled attacker.
参考资料
portswigger/web-security/os-command-injection
pwn.college/inter/web-security/cmdi
文档信息
- 本文作者:seamaner
- 本文链接:https://seamaner.github.io/2024/11/14/os-cmd-injection/
- 版权声明:自由转载-非商用-非衍生-保持署名(创意共享3.0许可证)