它在 Python 文档中声明pickle
不安全,不应解析不受信任的用户输入。如果你研究这个;几乎所有示例都system()
通过调用 via 来证明这一点os.system
。
我不清楚的是,在没有导入模块的情况下如何os.system
正确解释。os
>>> import pickle
>>> pickle.loads("cos\nsystem\n(S'ls /'\ntR.") # This clearly works.
bin boot cgroup dev etc home lib lib64 lost+found media mnt opt proc root run sbin selinux srv sys tmp usr var
0
>>> dir() # no os module
['__builtins__', '__doc__', '__name__', '__package__', 'pickle']
>>> os.system('ls /')
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
NameError: name 'os' is not defined
>>>
有人可以解释吗?