【问题标题】:Bash Script for Openvas OMPOpenvas OMP 的 Bash 脚本
【发布时间】:2014-05-13 18:30:53
【问题描述】:

我正在编写一个脚本,试图让 OpenVAS OMP 完全自动化。该脚本应该能够询问什么类型的扫描,ip,名称,评论,输出类型。它遍历所有菜单,然后显示以下内容:

Failed to read response.
Starting Scan
Failed to start task.
Failed to read response.
get-report requires one argument.

我有它 echo 开始扫描,但其余的我不确定它们是如何出现的以及为什么。当我在脚本之外运行每个命令时,它们确实有效,所以我猜测它与读取变量的方式有关。代码如下,非常感谢任何帮助。

#!/bin/sh

mkdir openvastmp 
cd openvastmp

echo "--------------------------------"
echo "----DamOS OpenVAS Automation----"
echo "------Select Type of Scan-------"
echo ""
echo "[1] Full and Fast"
echo "[2] Full and Fast Ultimate"
echo "[3] Full and very Deep"
echo "[4] Full and very Deep Ultimate"
echo "[5] Exit"
echo ""
echo "--------------------------------"

read -p "Please select an option: " m

if [ $m -eq 5 ]; then
exit 0;

elif [ $m -eq 1 ]; then
type="daba56c8-73ec-11df-a475-002264764cea"

elif [ $m -eq 2 ]; then
type="698f691e-7489-11df-9d8c-002264764cea"

elif [ $m -eq 3 ]; then
type="708f25c4-7489-11df-8094-002264764cea"

elif [ $m -eq 4 ]; then 
type="74db13d6-7489-11df-91b9-002264764cea"

fi
clear

echo "" #remove this line after
echo "--------------------------------" 
echo "----DamOS OpenVAS Automation----" 
echo "-----------Target Info----------"
read -p "Enter the IP of the target machine: " a
read -p "Enter the name you want the target stored as: " b
read -p "Enter what you would like to name the scan: " d
read -p "Enter a comment for the scan (not required): " e

omp -u user -w password --xml='
<create_target>
<name>'$b'</name>
<hosts>'$a'</hosts>
</create_target>'

echo "--------------------------------"
echo "----DamOS OpenVAS Automation----" 
echo "-------Report Output Type-------" 
echo "[1] HTML"
echo "[2] PDF"
echo "[3] Text"
echo "[4] XML"
echo "[5] Quit"
read -p "Select your desired report output format: " c

if [ $c -eq 5 ]; then
exit 0;
elif [ $c -eq 1 ]; then
report="6c248850-1f62-11e1-b082-406186ea4fc5"
ext=html
elif [ $c -eq 2 ]; then
report="c402cc3e-b531-11e1-9163-406186ea4fc5"
ext=pdf
elif [ $c -eq 3 ]; then
report="a3810a62-1f62-11e1-9219-406186ea4fc5"
ext=txt
elif [ $c -eq 4 ]; then 
report="a994b278-1f62-11e1-96ac-406186ea4fc5"
ext=xml
fi
clear

omp -u user -w password -T | grep $b > target
targetid=$(head -c 36 target)

omp -u user -w password -iX '
<create_task>
<name>'$d'</name>
<comment>'$e'</comment>
<config id='$type'/>
<target id='$targetid'/>
</create_task>'

#omp -u user -w password -C -n $d -m $e -c $type -t $targetid

omp -u user -w password -G | grep $b > scan
scanid=$(head -c 36 scan)

echo "Starting Scan"
#omp -u user -w password --xml='<start_task task_id='$scanid'/>'
omp -u user -w password -S $scanid

omp -u user -w password -G | grep Done > isdone

while [ ! -s isdone ];
do
    rm isdone
    sleep 5
    omp -u user -w password -G | grep Done > isdone
done

omp -u user -w password -iX '<get_tasks task_id='$scanid' details="1"/>' | grep     'report id' > reportid

reportid=$(awk '{print substr($0,22,64)}' reportid)

omp -u user -w password --get-report $reportid --format $report > $d.$ext

omp -u user -w password -D $scanid

omp -u user -w password -X '<delete_target target_id="'$targetid'"/>'

cd .. && rm -rf openvastmp

【问题讨论】:

  • 当您使用-xml 标志时,您将shell 变量放在单引号内,shell 不会将其扩展为实际值,但将被视为文字。如果你用双引号替换这些会发生什么?
  • xml标签后或变量周围的单引号?
  • 两者都有!我也很好奇哪个omp 命令给出了Failed to read response. 错误
  • 我会试一试,我现在有一些会议,但一旦我回到实际工作中我会通知你的。我会让你知道是什么导致了这些错误。
  • 所以我实际上知道 Failed to read 响应错误是什么。它们实际上是当系统将数据传输到文件时,因为它看不到响应代码。

标签: bash shell variables sh openvas


【解决方案1】:

当你使用 XML 代码时,它不会将 $a$b 理解为变量,而是将其理解为字符串 $a$b。我的代码也遇到了同样的问题。如果您在 XML 代码之前传递变量,则不会有问题。

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2014-09-20
    • 2013-02-05
    • 2017-01-11
    • 2014-03-12
    • 2019-05-23
    • 1970-01-01
    相关资源
    最近更新 更多