属性错误: 'NoneType'对象没有属性'text'分析 XML 文件



我正在使用一个程序来解析OpenVAS(其他人的代码(中的xml文件,我得到了AttributeError: 'NoneType' object has no attribute 'text'。这在某种程度上是意料之中的,因为;主机名";对于某些扫描,字段可能为空。理想情况下,如果主机名为空,则只应将N/A作为主机名。

错误:

File "/var/lib/openvasreporting/openvasreporting/libs/parser.py", line 115, in openvas_parser
vuln_host_name = vuln.find("./host/hostname").text
AttributeError: 'NoneType' object has no attribute 'text'

以下是parser.py文件中的相应行:

# --------------------
#
# VULN_HOST
vuln_host = vuln.find("./host").text
vuln_host_name = vuln.find("./host/hostname").text
if vuln_host_name is None:
vuln_host_name = "N/A"
logging.debug("* hostname:t{}".format(vuln_host_name))  # DEBUG
vuln_port = vuln.find("./port").text
logging.debug(
"* vuln_host:t{} port:t{}".format(vuln_host, vuln_port))  # DEBUG
# --------------------

附带说明一下,这是parser.py文件的另外两个部分中的一个错误。这就是已解析部分的样子:

# --------------------
#
# VULN_CVES
#vuln_cves = nvt_tmp.findall("./refs/ref")
vuln_cves = []
ref_list = []
for reference in nvt_tmp.findall('./refs/ref'):
if reference.attrib.get('type') == 'cve':
vuln_cves.append(reference.attrib.get('id'))
else:
ref_list.append(reference.attrib.get('id'))
logging.debug("* vuln_cves:t{}".format(vuln_cves))  # DEBUG
logging.debug("* vuln_cves:t{}".format(Et.tostring(vuln_cves).decode()))  # DEBUG
if vuln_cves is None or vuln_cves.text.lower() == "nocve":
vuln_cves = []
else:
vuln_cves = [vuln_cves.text.lower()]
vuln_references = ' , '.join(ref_list)
logging.debug("* vuln_cves:t{}".format(vuln_cves))  # DEBUG
logging.debug("* vuln_references:t{}".format(vuln_references))
# --------------------
#
# VULN_REFERENCES
vuln_references = nvt_tmp.find("./xref")
if vuln_references is None or vuln_references.text.lower() == "noxref":
vuln_references = []
else:
vuln_references = vuln_references.text.lower().replace("url:", "n")
logging.debug("* vuln_references:t{}".format(vuln_references))  # DEBUG
#
# --------------------

我试着用else: pass添加它,但我得到了相同的结果。

我不是一个真正的程序员,所以如果没有所有相关信息,我很抱歉。

之所以会发生这种情况,是因为您正在调用find(),然后立即访问.text属性,而不检查find()是否真的找到了任何内容。

改为这样做:

element = vuln.find("./host/hostname")
if element:
vuln_host_name = element.text
else:
vuln_host_name = "N/A"

替换:

vuln_host = vuln.find("./host").text

带有:

if vuln.find("./host") > -1:
vuln_host = vuln.find("./host").text
else:
vuln_host = "N/A"

最新更新