漏洞扫描引擎实现方法、装置、漏洞扫描方法及电子设备与流程



1.本技术涉及计算机技术领域,具体而言,涉及一种漏洞扫描引擎实现方法、装置、漏洞扫描方法及电子设备。


背景技术:



2.主机漏洞扫描是基于主机模式的一种扫描方法,也是基于漏洞数据库,通过扫描等手段对指定的远程或者本地计算机漏洞系统的安全脆弱性进行检测,发现漏洞的一种安全检测行为。
3.通过网络漏洞、安全漏洞扫描,系统管理员能够发现所维护的web服务器的各种tcp/ip端口的分配、开放的服务、web服务软件版本、以及这些服务及软件呈现在网络上的安全漏洞。网络安全漏洞扫描技术也是采用积极的、非破坏性的办法来检验系统是否有可能被攻击崩溃,其利用了一系列的脚本模拟对系统进行攻击的行为,并对结果进行分析。这种技术通常被用来进行模拟攻击实验和安全审计。
4.目前一般会使用openvas进行漏洞扫描。openvas是greenbone network的商业漏洞管理解决方案的一部分,它是一个集成了多个服务和工具的框架,提供了强大而全面的漏洞扫描和漏洞管理解决方案。然而,开源的openvas已经形成了完整的框架,包含了众多必要组件,部署相对复杂,而且不易于扩展。


技术实现要素:



5.本技术提供了一种漏洞扫描引擎实现方法、漏洞扫描方法、装置、电子设备及可读存储介质,其能够基于开源编程语言golang实现漏洞扫描引擎,该引擎继承了go语言高性能的特点,方便分析定位问题,部署方便,并且该引擎基于漏洞扫描插件实现漏洞扫描,可以很方便地扩展漏洞扫描插件。
6.本技术的实施例可以这样实现:
7.第一方面,本技术实施例提供一种漏洞扫描引擎实现方法,所述漏洞扫描引擎包括扫描器及漏洞扫描插件,所述扫描器包括词法解析器、待使用函数、插件加载器、调度器及结果解析单元,所述方法包括:
8.根据yacc词法解析器的标准,使用go语言实现目标语言的语法,以得到所述词法解析器,其中,所述目标语言为所述漏洞扫描插件使用的语言;
9.利用go语言生成所述待使用函数、插件加载器、调度器及结果解析单元;
10.获得多个漏洞扫描插件;
11.根据生成的所述扫描器及所述多个漏洞扫描插件,生成安装包。
12.第二方面,本技术实施例提供一种漏洞扫描方法,所述方法包括:
13.向漏洞扫描引擎输入扫描参数,其中,所述漏洞扫描引擎基于前述实施方式中任意一项所述的漏洞扫描引擎实现方法得到,对所述扫描参数进行控制的方式包括通过命令行、文件、环境变量配置方式,所述扫描参数包括扫描目标列表及插件列表,所述扫描目标
列表中包括至少一个扫描目标,所述插件列表中包括所述漏洞扫描插件的插件标识;
14.利用所述漏洞扫描引擎根据所述扫描参数进行扫描,得到扫描汇总结果。
15.第三方面,本技术实施例提供一种漏洞扫描引擎实现装置,所述漏洞扫描引擎包括扫描器及漏洞扫描插件,所述扫描器包括词法解析器、待使用函数、插件加载器、调度器及结果解析单元,所述装置包括:
16.第一获得模块,用于根据yacc词法解析器的标准,使用go语言实现目标语言的语法,以得到所述词法解析器,其中,所述目标语言为所述漏洞扫描插件使用的语言;
17.所述第一获得模块,还用于利用go语言生成所述待使用函数、插件加载器、调度器及结果解析单元;
18.第二获得模块,用于获得多个漏洞扫描插件;
19.安装包生成模块,用于根据生成的所述扫描器及所述多个漏洞扫描插件,生成安装包。
20.第四方面,本技术实施例提供一种漏洞扫描装置,所述装置包括:
21.控制模块,用于向漏洞扫描引擎输入扫描参数,其中,所述漏洞扫描引擎基于所述的漏洞扫描引擎实现方法得到,对所述扫描参数进行控制的方式包括通过命令行、文件、环境变量配置方式,所述扫描参数包括扫描目标列表及插件列表,所述扫描目标列表中包括至少一个扫描目标,所述插件列表中包括所述漏洞扫描插件的插件标识;
22.扫描模块,用于利用所述漏洞扫描引擎根据所述扫描参数进行扫描,得到扫描汇总结果。
23.第五方面,本技术实施例提供一种电子设备,包括处理器和存储器,所述存储器存储有能够被所述处理器执行的机器可执行指令,所述处理器可执行所述机器可执行指令以实现前述实施方式所述的漏洞扫描引擎实现方法,或实现前述实施方式所述的漏洞扫描方法。
24.第六方面,本技术实施例提供一种可读存储介质,其上存储有计算机程序,所述计算机程序被处理器执行时实现如前述实施方式所述的方法。
25.本技术实施例提供的漏洞扫描引擎实现方法、漏洞扫描方法、装置、电子设备及可读存储介质,漏洞扫描引擎包括扫描器及漏洞扫描插件,所述扫描器包括词法解析器、待使用函数、插件加载器、调度器及结果解析单元;根据yacc词法解析器的标准,使用go语言实现目标语言的语法,以得到所述词法解析器,其中,所述目标语言为所述漏洞扫描插件使用的语言;并利用go语言生成所述待使用函数、插件加载器、调度器及结果解析单元;以及获得多个漏洞扫描插件;最后,根据生成的所述扫描器及所述多个漏洞扫描插件,生成安装包。如此,基于go语言实现漏洞扫描引擎,该引擎继承了go语言高性能的特点,方便分析定位问题,部署方便,并且可以很方便地扩展漏洞扫描插件。
附图说明
26.为了更清楚地说明本发明实施例的技术方案,下面将对实施例中所需要使用的附图作简单地介绍,应当理解,以下附图仅示出了本发明的某些实施例,因此不应被看作是对范围的限定,对于本领域普通技术人员来讲,在不付出创造性劳动的前提下,还可以根据这些附图获得其他相关的附图。
programmable read-only memory,eeprom)等。
42.处理器120用于读/写存储器110中存储的数据或程序,并执行相应地功能。比如,存储器110中存储有漏洞扫描引擎实现装置或漏洞扫描装置,所述装置包括至少一个可以软件或固件(firmware)的形式存储于所述存储器110中的软件功能模块。所述处理器120通过运行存储在存储器110内的软件程序以及模块,如本技术实施例中的漏洞扫描引擎实现装置,从而执行各种功能应用以及数据处理,即实现本技术实施例中的漏洞扫描引擎实现方法;再比如,所述处理器120通过运行漏洞扫描装置,实现本技术实施例中的漏洞扫描方法。
43.通信单元130用于通过网络建立所述电子设备100与其它通信终端之间的通信连接,并用于通过所述网络收发数据。
44.应当理解的是,图1所示的结构仅为电子设备100的结构示意图,所述电子设备100还可包括比图1中所示更多或者更少的组件,或者具有与图1所示不同的配置。图1中所示的各组件可以采用硬件、软件或其组合实现。
45.请参照图2,图2为本技术实施例提供的漏洞扫描引擎实现方法的流程示意图。所述方法可应用于上述电子设备100。下面对漏洞扫描引擎实现方法的具体流程进行详细阐述。在本实施例中,所述漏洞扫描引擎包括扫描器及漏洞扫描插件,所述扫描器包括词法解析器、待使用函数、插件加载器、调度器及结果解析单元。所述方法包括步骤s110~步骤s140。
46.步骤s110,根据yacc词法解析器的标准,使用go语言实现目标语言的语法,以得到所述词法解析器。
47.在本实施例中,可根据yacc词法解析器的定制标准,利用go语言实现目标语言的语法,从而使用go语言生成所述词法解析器。该过程可以为:按照yacc词法解析器的语法,利用go语言写好对应的语法文件,使用yacc工具生成对应的go语言版本的解析器。
48.其中,所述目标语言为所述漏洞扫描插件使用的语言。所述词法解析器用于将基于目标语言的插件解析为语法树。比如,若所述目标语言为nasl,则上述步骤为使用yacc生成go语言版本的nasl词法解析器,nasl词法解析器可以将nasl插件解析为语法树。
49.其中,go(golang)是google开发的一种静态强类型、编译型、并发型,并具有垃圾回收功能的编程语言。nasl(nessus attack scripting language)是一种为nessus安全扫描器所设计的脚本语言,它的目的在于使每个人都可以在几分钟内对给定的安全漏洞写出测试代码,并允许人们分享他们的测试代码而不用担心自己使用的使什么操作系统。
50.步骤s120,利用go语言生成所述待使用函数、插件加载器、调度器及结果解析单元。
51.在本实施例中,还可以利用go语言生成漏洞扫描引擎在用于漏洞扫描时需要使用到的函数。所述待使用函数可以是所述词法解析器进行词法解析时需要使用的函数,具体可以结合实际需求设置。
52.还可以通过go语言生成插件加载器,所述插件加载器用于在需要利用该漏洞扫描引擎进行漏洞扫描时加载相应的漏洞扫描插件。
53.还可以通过go语言生成调度器及结果解析单元,所述调度器用于在进行任务分配、管理等,所述结果解析单元用于对通过执行漏洞扫描插件获得的信息进行汇总,以得到
扫描汇总结果。
54.步骤s130,获得多个漏洞扫描插件。
55.获得的所述漏洞扫描插件使用的语言为所述目标语言。
56.步骤s140,根据生成的所述扫描器及所述多个漏洞扫描插件,生成安装包。
57.通过步骤s110及步骤s120可以利用go语言实现扫描器,进而基于生成的扫描器与得到的多个漏洞扫描插件,生成漏洞扫描引擎对应的安装包。
58.如此,基于开源编程语言golang实现了漏洞扫描引擎,该漏洞扫描引擎继承了go语言高性能的特点,方便分析定位问题。例如,go提供pprof工具,可以分析内存、cpu使用情况;还提供了trace工具,可以方便地追踪堆栈调用情况;而基于内存、cpu使用情况以及堆栈调用情况等,便于对问题进行分析及定位。并且,本技术实施例实现的漏洞扫描引擎主要用于漏洞扫描,不包括用于实现其他服务的组件,因此占用资源少、部署方便。此外,该漏洞扫描引擎使用现有的漏洞扫描插件语言,可以很方便地扩展漏洞扫描插件。
59.作为一种可能的实现方式,所述漏洞扫描插件为nasl插件,所述目标语言为nasl,所述标语言的语法为nasl。利用go语言实现的扫描器中包括用于解析nasl插件的nasl词法解析器,利用该nasl词法解析器将加载的插件解析后,可按照nasl代码来执行响应的网络请求操作。
60.利用go语言实现的具体nasl语法,可以结合实际需求确定。比如,实现的nasl语法包括类型定义、基本运算符定义、算数操作、字符串操作、比较运算符、逻辑运算符、位运算符、循环控制流、变量定义、函数定义、函数调用等中的至少一个语法。
61.作为一种可能的实现方式,所述待使用函数包括nasl语言的内置函数及nasl库函数。所述待使用函数可以包括知识库函数、报告生成函数、描述函数、胶水函数、网络函数、字符串操作函数、http函数、ip操作函数、密码处理函数等中的至少一种。
62.知识库是用来存储每个插件运行过程中产生的中间值,提供给后续运行的插件使用,避免重复逻辑。知识库函数是对知识库进行插入值、取值等操作的函数,比如:set_kb_item、get_kb_item等函数。
63.在所述待使用函数包括知识库函数时,还可以基于redis数据库构建知识库。其中,所述知识库函数用于对所述知识库进行操作,所述知识库用于记录扫描过程中发现的信息。即,基于redis实现对nasl中“set_kb_item”、“get_kb_item”等知识库函数的支持。可以将插件扫描过程中发现的主机信息(可以包括端口的分配、开放的服务、服务软件版本等)记录下来,方便后续插件使用,减少重复扫描、提高扫描效率。
64.还可以将其他资产扫描工具,比如,nmap、zmap、masscan,扫描到的数据集成到该知识库中,以对知识库信息进行扩充。比如,将利用其他工具扫描的端口信息存储在该知识库中。如此,可以减少扫描插件的重复运行。
65.插件之间会存在依赖关系。比如,后一个插件可以根据前一个插件扫描到的80端口上运行的服务,确定是否执行以判断服务版本。插件a用于判断服务1的版本,若80端口上运行的服务不包括服务1,则插件a可以不运行。插件和插件之间通过知识库进行信息交流。
66.在本实施例中,针对所述扫描器,可以通过命令行、文件、环境变量三种配置方式实现扫描参数的控制。所述扫描参数可以包括:扫描目标列表、插件列表、超时时间、redis、日志等配置。使用go语言标准库中的falag库实现命令行的解析,使用yaml格式的配置文
件。所述扫描目标列表中包括需要被扫描的扫描目标,每个扫描目标可以用一个ip地址表示。所述插件列表中可以包括要使用的漏洞扫描插件的插件标识。在针对redis进行配置时,可以配置redis的地址、用户名、密码等,便于基于该配置便于将相关信息保存知识库中。针对日志进行配置时,可以配置输出的文件名、日志等级等,所述日志等级用于表示日志中需要记录的信息类型。
67.所述插件加载器用于根据配置加载漏洞扫描插件,并通过基于步骤s110获得的词法解析器进行解析。该解析过程可以分为:预加载和执行,在预加载过程中,插件加载器读取插件,词法解析器对插件进行插件依赖关系的分析及插件的优先级分析,以形成插件依赖链表。其中,不同等级的插件的执行顺序基于各插件所对应的优先级确定。然后,插件按照依赖链表依次执行,后面执行的插件可以通过知识库来引用前面执行的插件的结果。
68.其中,加载的具体漏洞扫描插件可以结合实际情况确定。比如,可以加载插件列表中对应的所有插件,也可以仅加载部分插件,或者,可以在用户或其他设备指定了不同扫描目标对应的漏洞扫描插件的情况下,针对某扫描目标进行扫描时,仅加载该扫描目标对应的漏洞扫描插件。
69.所述调度器可以利用go语言groutine特性对多个目标并行扫描。在该过程中,所述调度器可以将多个目标和多个插件划分到多个“worker”中执行,提高cpu利用率,加快扫描速度。其中,一个目标及该目标对应的插件被分配一个“worker”上,不同目标可位于不同的“worker”。
70.所述结果解析单元用于将每个扫描目标的扫描结果聚合,得到聚合结果;以及,在有插件生成了cpe信息的情况下,针对各插件生成的cpe信息,可以将该cpe信息与预设的组件表进行匹配,得到匹配结果。其中,所述组件表中包括不同组件各自对应的漏洞情况,经过与所述组件表的匹配,可以确定该cpe信息对应的漏洞是否存在。可以将上述聚合结果及匹配结果最终的输出的扫描汇总结果。
71.请参照图3,图3为图2中步骤s140包括的子步骤的流程示意图。在本实施例中,步骤s140可以包括子步骤s141~子步骤s142。
72.子步骤s141,根据预设的多个不同平台类型,将go语言的扫描器文件通过交叉编译,得到与不同平台类型对应的二进制文件。
73.子步骤s142,针对各平台类型对应的二进制文件,根据该平台类型的二进制文件及所述多个漏洞扫描插件,生成与该平台类型对应的安装包。
74.比如,平台类型有:windows、linux、macos平台,则可以将go语言的扫描器文件通过交叉编译,得到上述三种平台类型各自对应的二进制文件,即编译为二进制可执行程序。其中,windows下的是.exe后缀的可执行文件,linux和macos都是类unix系统,没有后缀,就是可执行文件。在获得3种二进制文件后,可以分别根据一种二进制文件与所述多个漏洞扫描插件生成一个压缩包,以得到3个安装包。一个安装包中包括一个平台类型对应的二进制文件及所述多个漏洞扫描插件。如此,部署简单,且可以实现多个平台移植。
75.在本实施例中,使用go语言实现漏洞扫描引擎,在需要对nasl函数做调整时,直接修改源代码中nasl语言的实现部分即可,因而可以方便地对nasl函数实现进行控制,利于程序分析和优化。并且,可以集成资产扫描工具数据来扩展知识库信息。还可以通过对cpe的分析实现组件匹配功能,扩展漏洞扫描数据。还能够利用go语言并发性能高的特点提高
扫描效率。该引擎中使用现有nasl插件语言,可以方便地实现对漏洞扫描插件的扩展。
76.请参照图4,图4为本技术实施例提供的漏洞扫描方法的流程示意图。在本实施例中,所述方法可以包括步骤s210~步骤s220。
77.步骤s210,向漏洞扫描引擎输入扫描参数。
78.其中,所述漏洞扫描引擎基于上述的漏洞扫描引擎实现方法得到。对所述扫描参数进行控制的方式包括通过命令行、文件、环境变量配置方式,所述扫描参数包括扫描目标列表及插件列表,所述扫描目标列表中包括至少一个扫描目标,所述插件列表中包括所述漏洞扫描插件的插件标识。
79.步骤s220,利用所述漏洞扫描引擎根据所述扫描参数进行扫描,得到扫描汇总结果。
80.在本实施例中,所述扫描汇总结果可以包括聚合结果及匹配结果。可通过图5所示方式获得所述扫描汇总结果。请参照图5,图5为图4中步骤s220包括的子步骤的流程示意图。在本实施例中,步骤s220可以包括子步骤s221~子步骤s223。
81.子步骤s221,基于所述扫描参数,所述扫描器针对各扫描目标执行相应的漏洞扫描插件,获得各漏洞扫描插件得到的扫描结果及cpe信息。
82.可选地,在所述漏洞扫描插件为nasl插件时,插件的执行方式可如图6所示。请参照图6,图6为图5中子步骤s221包括的子步骤的流程示意图。在本实施例中,子步骤s221可以包括子步骤s2211~子步骤s2212。
83.子步骤s2211,利用所述插件加载器读取nasl插件,并通过所述词法解析器对读取的nasl插件进行解析,以获得插件依赖链表。
84.子步骤s2212,按照所述插件依赖链表依次执行所述nasl插件,并将执行结果保存至知识库中,以便其他nasl插件使用。
85.其中,所述解析包括插件依赖关系的分析及插件的优先级分析。
86.nasl插件解析的过程可以分为预加载和执行。预加载过程中,通过对nasl插件中的“script_dependices”函数中插件依赖的分析,并按照“script_category”函数中设置的分类,形成插件依赖链表,插件按照依赖链表依次执行,后面执行的插件可以通过知识库来引用前面执行的插件的结果。其中,“script_dependices”在插件中调用,用于设置该插件依赖的其他插件。每一个插件都会调用script_category函数。
87.比如,可根据script_category函数将运行需要的插件分为10个等级,先运行等级为1的插件,而等级为1的插件,又有script_depencies设置好的依赖关系,所以等级为1的插件也需要按照script_depencies函数设置的依赖关系来决定运行的先后顺序。因此,可以基于script_dependices函数及script_category函数得到的插件依赖链表。
88.另外,在所述扫描器执行漏洞扫描插件时,所述调度器可以利用go语言groutine特性,对所述多个扫描目标进行并行扫描,以提高cpu利用率、加快扫描速度。
89.通过执行漏洞扫描插件,可得到各漏洞扫描插件输出的扫描结果。部分漏洞扫描还会生成cpe信息。
90.子步骤s222,所述结果解析单元针对各扫描目标,将该扫描目标对应的扫描结果进行聚合,得到所述聚合结果。
91.通过对扫描结果进行聚合,可以使结果看起来更加直观。
92.子步骤s223,所述结果解析单元将各漏洞扫描插件得到的cpe信息与预设的组件表进行匹配,得到所述匹配结果。
93.其中,所述组件表中包括不同组件各自对应的漏洞情况。
94.为了执行上述实施例及各个可能的方式中的相应步骤,下面给出一种漏洞扫描引擎实现装置200及漏洞扫描装置300的实现方式,可选地,该装置可以采用上述图1所示的电子设备100的器件结构。需要说明的是,本实施例所提供的装置,其基本原理及产生的技术效果和上述实施例相同,为简要描述,本实施例部分未提及之处,可参考上述的实施例中相应内容。
95.请参照图7,图7为本技术实施例提供的漏洞扫描引擎实现装置200的方框示意图。所述漏洞扫描引擎包括扫描器及漏洞扫描插件,所述扫描器包括词法解析器、待使用函数、插件加载器、调度器及结果解析单元。所述漏洞扫描引擎实现装置200可以包括:第一获得模块210、第二获得模块220及安装包生成模块230。
96.所述第一获得模块210,用于根据yacc词法解析器的标准,使用go语言实现目标语言的语法,以得到所述词法解析器。其中,所述目标语言为所述漏洞扫描插件使用的语言。
97.所述第一获得模块210,还用于利用go语言生成所述待使用函数、插件加载器、调度器及结果解析单元。
98.所述第二获得模块220,用于获得多个漏洞扫描插件。
99.所述安装包生成模块230,用于根据生成的所述扫描器及所述多个漏洞扫描插件,生成安装包。
100.请参照图8,图8为本技术实施例提供的漏洞扫描装置300的方框示意图。所述漏洞扫描装置300可以包括:控制模块310及扫描模块320。
101.所述控制模块310,用于向漏洞扫描引擎输入扫描参数。其中,所述漏洞扫描引擎基于所述的漏洞扫描引擎实现方法得到,对所述扫描参数进行控制的方式包括通过命令行、文件、环境变量配置方式,所述扫描参数包括扫描目标列表及插件列表,所述扫描目标列表中包括至少一个扫描目标,所述插件列表中包括所述漏洞扫描插件的插件标识。
102.所述扫描模块320,用于利用所述漏洞扫描引擎根据所述扫描参数进行扫描,得到扫描汇总结果。
103.可选地,上述模块可以软件或固件(firmware)的形式存储于图1所示的存储器110中或固化于电子设备100的操作系统(operating system,os)中,并可由图1中的处理器120执行。同时,执行上述模块所需的数据、程序的代码等可以存储在存储器110中。
104.本技术实施例还提供一种可读存储介质,其上存储有计算机程序,所述计算机程序被处理器执行时实现所述的漏洞扫描引擎实现方法或者漏洞扫描方法。
105.综上所述,本技术实施例提供一种漏洞扫描引擎实现方法、漏洞扫描方法、装置、电子设备及可读存储介质,漏洞扫描引擎包括扫描器及漏洞扫描插件,所述扫描器包括词法解析器、待使用函数、插件加载器、调度器及结果解析单元;根据yacc词法解析器的标准,使用go语言实现目标语言的语法,以得到所述词法解析器,其中,所述目标语言为所述漏洞扫描插件使用的语言;并利用go语言生成所述待使用函数、插件加载器、调度器及结果解析单元;以及获得多个漏洞扫描插件;最后,根据生成的所述扫描器及所述多个漏洞扫描插件,生成安装包。如此,基于go语言实现漏洞扫描引擎,该引擎继承了go语言高性能的特点,
方便分析定位问题,部署方便,并且可以很方便地扩展漏洞扫描插件。
106.在本技术所提供的几个实施例中,应该理解到,所揭露的装置和方法,也可以通过其它的方式实现。以上所描述的装置实施例仅仅是示意性的,例如,附图中的流程图和框图显示了根据本技术的多个实施例的装置、方法和计算机程序产品的可能实现的体系架构、功能和操作。在这点上,流程图或框图中的每个方框可以代表一个模块、程序段或代码的一部分,所述模块、程序段或代码的一部分包含一个或多个用于实现规定的逻辑功能的可执行指令。也应当注意,在有些作为替换的实现方式中,方框中所标注的功能也可以以不同于附图中所标注的顺序发生。例如,两个连续的方框实际上可以基本并行地执行,它们有时也可以按相反的顺序执行,这依所涉及的功能而定。也要注意的是,框图和/或流程图中的每个方框、以及框图和/或流程图中的方框的组合,可以用执行规定的功能或动作的专用的基于硬件的系统来实现,或者可以用专用硬件与计算机指令的组合来实现。
107.另外,在本技术各个实施例中的各功能模块可以集成在一起形成一个独立的部分,也可以是各个模块单独存在,也可以两个或两个以上模块集成形成一个独立的部分。
108.所述功能如果以软件功能模块的形式实现并作为独立的产品销售或使用时,可以存储在一个计算机可读取存储介质中。基于这样的理解,本技术的技术方案本质上或者说对现有技术做出贡献的部分或者该技术方案的部分可以以软件产品的形式体现出来,该计算机软件产品存储在一个存储介质中,包括若干指令用以使得一台计算机设备(可以是个人计算机,服务器,或者网络设备等)执行本技术各个实施例所述方法的全部或部分步骤。而前述的存储介质包括:u盘、移动硬盘、只读存储器(rom,read-only memory)、随机存取存储器(ram,random access memory)、磁碟或者光盘等各种可以存储程序代码的介质。
109.以上所述仅为本技术的可选实施例而已,并不用于限制本技术,对于本领域的技术人员来说,本技术可以有各种更改和变化。凡在本技术的精神和原则之内,所作的任何修改、等同替换、改进等,均应包含在本技术的保护范围之内。

技术特征:


1.一种漏洞扫描引擎实现方法,其特征在于,所述漏洞扫描引擎包括扫描器及漏洞扫描插件,所述扫描器包括词法解析器、待使用函数、插件加载器、调度器及结果解析单元,所述方法包括:根据yacc词法解析器的标准,使用go语言实现目标语言的语法,以得到所述词法解析器,其中,所述目标语言为所述漏洞扫描插件使用的语言;利用go语言生成所述待使用函数、插件加载器、调度器及结果解析单元;获得多个漏洞扫描插件;根据生成的所述扫描器及所述多个漏洞扫描插件,生成安装包。2.根据权利要求1所述的方法,其特征在于,所述漏洞扫描插件为nasl插件,所述目标语言的语法为nasl语法,所述nasl语法包括类型定义、基本运算符定义、算数操作、字符串操作、比较运算符、逻辑运算符、位运算符、循环控制流、变量定义、函数定义、函数调用中的至少一个语法;和/或,所述待使用函数包括nasl语言的内置函数及nasl库函数,所述待使用函数包括知识库函数、报告生成函数、描述函数、胶水函数、网络函数、字符串操作函数、http函数、ip操作函数、密码处理函数中的至少一种。3.根据权利要求1所述的方法,其特征在于,在所述待使用函数包括知识库函数时,所述方法还包括:基于redis数据库构建知识库,其中,所述知识库函数用于对所述知识库进行操作,所述知识库用于记录扫描过程中发现的信息。4.根据权利要求1-3中任意一项所述的方法,其特征在于,所述根据生成的所述扫描器及所述多个漏洞扫描插件,生成安装包,包括:根据预设的多个不同平台类型,将go语言的扫描器文件通过交叉编译,得到与不同平台类型对应的二进制文件;针对各平台类型对应的二进制文件,根据该平台类型的二进制文件及所述多个漏洞扫描插件,生成与该平台类型对应的安装包。5.一种漏洞扫描方法,其特征在于,所述方法包括:向漏洞扫描引擎输入扫描参数,其中,所述漏洞扫描引擎基于权利要求1-4中任意一项所述的漏洞扫描引擎实现方法得到,对所述扫描参数进行控制的方式包括通过命令行、文件、环境变量配置方式,所述扫描参数包括扫描目标列表及插件列表,所述扫描目标列表中包括至少一个扫描目标,所述插件列表中包括所述漏洞扫描插件的插件标识;利用所述漏洞扫描引擎根据所述扫描参数进行扫描,得到扫描汇总结果。6.根据权利要求5所述的方法,其特征在于,所述扫描汇总结果包括聚合结果及匹配结果,所述利用所述漏洞扫描引擎根据所述扫描参数进行扫描,得到扫描汇总结果,包括:基于所述扫描参数,所述扫描器针对各扫描目标执行相应的漏洞扫描插件,获得各漏洞扫描插件得到的扫描结果及cpe信息;所述结果解析单元针对各扫描目标,将该扫描目标对应的扫描结果进行聚合,得到所述聚合结果;所述结果解析单元将各漏洞扫描插件得到的cpe信息与预设的组件表进行匹配,得到所述匹配结果,其中,所述组件表中包括不同组件各自对应的漏洞情况。
7.根据权利要求6所述的方法,其特征在于,所述漏洞扫描插件为nasl插件,所述扫描器针对各扫描目标执行相应的漏洞扫描插件,包括:利用所述插件加载器读取nasl插件,并通过所述词法解析器对读取的nasl插件进行解析,以获得插件依赖链表,其中,所述解析包括插件依赖关系的分析及插件的优先级分析;按照所述插件依赖链表依次执行所述nasl插件,并将执行结果保存至知识库中,以便其他nasl插件使用。8.根据权利要求6所述的方法,其特征在于,在所述扫描目标列表中包括多个扫描目标时,所述扫描器针对各扫描目标执行相应的漏洞扫描插件,包括:所述调度器利用go语言groutine特性,对所述多个扫描目标进行并行扫描。9.一种漏洞扫描引擎实现装置,其特征在于,所述漏洞扫描引擎包括扫描器及漏洞扫描插件,所述扫描器包括词法解析器、待使用函数、插件加载器、调度器及结果解析单元,所述装置包括:第一获得模块,用于根据yacc词法解析器的标准,使用go语言实现目标语言的语法,以得到所述词法解析器,其中,所述目标语言为所述漏洞扫描插件使用的语言;所述第一获得模块,还用于利用go语言生成所述待使用函数、插件加载器、调度器及结果解析单元;第二获得模块,用于获得多个漏洞扫描插件;安装包生成模块,用于根据生成的所述扫描器及所述多个漏洞扫描插件,生成安装包。10.一种电子设备,其特征在于,包括处理器和存储器,所述存储器存储有能够被所述处理器执行的机器可执行指令,所述处理器可执行所述机器可执行指令以实现权利要求1-4中任意一项所述的漏洞扫描引擎实现方法,或实现权利要求5-8中任意一项所述的漏洞扫描方法。

技术总结


本申请实施例提供了一种漏洞扫描引擎实现方法、装置、漏洞扫描方法及电子设备,涉及计算机技术领域。漏洞扫描引擎包括扫描器及漏洞扫描插件,扫描器包括词法解析器、待使用函数、插件加载器、调度器及结果解析单元,该实现方法包括:根据yacc词法解析器的标准,使用Go语言实现目标语言的语法,以得到词法解析器,目标语言为漏洞扫描插件使用的语言;利用Go语言生成待使用函数、插件加载器、调度器及结果解析单元;获得多个漏洞扫描插件;根据生成的扫描器及多个漏洞扫描插件,生成安装包。如此,基于Go语言实现漏洞扫描引擎,该引擎继承了Go语言高性能的特点,方便分析定位问题,部署方便,并且可以很方便地扩展漏洞扫描插件。并且可以很方便地扩展漏洞扫描插件。并且可以很方便地扩展漏洞扫描插件。


技术研发人员:

曹晓栋 杨冀龙 赵伟

受保护的技术使用者:

北京知道创宇信息技术股份有限公司

技术研发日:

2022.10.08

技术公布日:

2022/12/30

本文发布于:2024-09-20 17:23:37,感谢您对本站的认可!

本文链接:https://www.17tex.com/tex/2/49320.html

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。

标签:所述   插件   漏洞扫描   语言
留言与评论(共有 0 条评论)
   
验证码:
Copyright ©2019-2024 Comsenz Inc.Powered by © 易纺专利技术学习网 豫ICP备2022007602号 豫公网安备41160202000603 站长QQ:729038198 关于我们 投诉建议