1 import subprocess
2 raw = raw_input("Filename:").lower()
3 ip = raw_input("Host:").lower()
4 cmd = subprocess.call("tcpdump -c5 -vvv -w" + " raw " + " ip ",shell=True)
这就是我的脚本。除了使用原始输入的一个关键目标之外,一切都正常。
它允许我输入任何我想要的东西,但是当它保存文件或使用 ip/主机时,doe 实际上并没有做任何事情。
当然它给了我数据包,但来自本地主机而不是我输入的主机。
我怎么知道这不起作用是因为我的第一个原始输入是文件名,所以我进行了测试,当我查看我的脚本所在的文件夹时,它会生成一个名为“raw”的文件,意思是,它实际上并没有采用我的仅使用我的“X”内的内容输入...
所以我找了几次机会来讨论这个问题:
1 import subprocess
2 raw = raw_input("Filename:").lower()
3 ip = raw_input("Host:").lower()
4 cmd = subprocess.call("tcpdump -c5 -vvv -w" + raw + "host" + ip,shell=True)
这很棒,因为它实际上需要 -w 但它现在将其保存为 rawhostip 而不是“raw”输入。
作为参考,命令在终端中如下所示:
tcpdump -c5 -vvv -w savename host wiki2
唯一的两个变量是 savename 和 wiki2 ,其余的变量是命令工作所必需的。
使用此脚本我收到此错误:
import subprocess
raw = raw_input("Filename:").lower()
ip = raw_input("Host:").lower()
cmd = subprocess.call("tcpdump -c5 -vvv -w" + raw, "host" + ip,shell=True)
Error:
Traceback (most recent call last):
File "te.py", line 4, in <module>
cmd = subprocess.call("tcpdump -c5 -vvv -w" + raw, "host" + ip,shell=True)
File "/usr/lib/python2.6/subprocess.py", line 480, in call
return Popen(*popenargs, **kwargs).wait()
File "/usr/lib/python2.6/subprocess.py", line 583, in __init__
raise TypeError("bufsize must be an integer")
TypeError: bufsize must be an integer
我迷路了。任何帮助都会很棒,是的,我知道在现场查看子流程的文档:X,我需要一个人来教我,我不明白我在读什么。
我的问题是如何处理这些变量。