移动终端抓取空中包的方法、装置、存储介质与移动终端与流程

文档序号:18884984发布日期:2019-10-15 20:45阅读:568来源:国知局
移动终端抓取空中包的方法、装置、存储介质与移动终端与流程

本公开涉及无线通信技术领域,尤其涉及一种移动终端抓取空中包的方法、移动终端抓取空中包的装置、计算机可读存储介质与移动终端。



背景技术:

无线网络的通信交互,是以空气为媒介进行的。抓取空中包即是对“空气中”的无线数据进行抓取、监听的技术,其对于监测通信状况、检查网络安全等有着重要意义。

手机、平板电脑等移动终端是常用的需要接入无线网络的设备,如果能够在移动终端上抓取空中包,则可以方便地对无线网络进行监测与检查。然而,如何采用移动终端抓取空中包,目前尚未有成熟的实现方法。

需要说明的是,在上述背景技术部分公开的信息仅用于加强对本公开的背景的理解,因此可以包括不构成对本领域普通技术人员已知的现有技术的信息。



技术实现要素:

本公开提供了一种移动终端抓取空中包的方法、移动终端抓取空中包的装置、计算机可读存储介质与移动终端,进而至少在一定程度上改善现有技术无法在移动终端上抓取空中包的问题。

本公开的其他特性和优点将通过下面的详细描述变得显然,或部分地通过本公开的实践而习得。

根据本公开的第一方面,提供一种移动终端抓取空中包的方法,包括:获取关于抓取空中包的设置参数;将所述设置参数传输至预设服务;通过所述预设服务调用无线网络接口,以根据所述设置参数设置所述无线网络接口;对流经所述无线网络接口的数据进行监听,以抓取空中包。

可选的,所述获取关于抓取空中包的设置参数,包括:呈现一用户界面(userinterface,ui),通过所述用户界面获取关于抓取空中包的设置参数。

可选的,所述将所述设置参数传输至预设服务,包括:将所述设置参数传输至所述用户界面关联的活动管理器;通过binder将所述设置参数从所述活动管理器分发至所述预设服务。

可选的,所述方法还包括:若接收到取消抓包的操作指令,则将所述无线网络接口的设置复原。

可选的,所述对流经所述无线网络接口的数据进行监听,包括:通过所述预设服务调用tcpdump对流经所述无线网络接口的数据进行监听。

可选的,在设置所述无线网络接口时,还将所述无线网络接口设置为监听模式(monitormode)或混杂模式(promiscuousmode)。

可选的,所述设置参数包括:信道与带宽,或者服务集标识(servicesetidentifier,ssid)。

根据本公开的第二方面,提供一种移动终端抓取空中包的装置,包括:参数获取模块,用于获取关于抓取空中包的设置参数;数据传输模块,用于将所述设置参数传输至预设的原生服务;无线设置模块,用于通过所述原生服务调用无线网络接口,以根据所述设置参数设置所述无线网络接口;数据监听模块,用于对流经所述无线网络接口的数据进行监听,以抓取空中包。

可选的,所述参数获取模块,用于呈现一用户界面,通过所述用户界面获取关于抓取空中包的设置参数。

可选的,所述数据传输模块,用于将所述设置参数传输至所述用户界面关联的活动管理器;通过binder将所述设置参数从所述活动管理器分发至所述预设服务。

可选的,所述无线设置模块,还用于若接收到取消抓包的操作指令,则将所述无线网络接口的设置复原。

可选的,所述数据监听模块,用于通过所述预设服务调用tcpdump对流经所述无线网络接口的数据进行监听。

可选的,所述无线设置模块,还用于在设置所述无线网络接口时,将所述无线网络接口设置为监听模式或混杂模式。

可选的,所述设置参数包括:信道与带宽,或者服务集标识。

根据本公开的第三方面,提供一种计算机可读存储介质,其上存储有计算机程序,所述计算机程序被处理器执行时实现上述任意一种抓取空中包的方法。

根据本公开的第四方面,提供一种移动终端,包括:处理器;存储器,用于存储所述处理器的可执行指令;以及无线网络接口;其中,所述处理器配置为经由执行所述可执行指令来执行上述任意一种抓取空中包的方法。

本公开具有以下有益效果:

移动终端上获取关于抓取空中包的设置参数后,通过预设服务调用无线网络接口进行设置,以对流经无线网络接口的数据进行监听,从而抓取空中包。一方面,提供了一种在手机、平板电脑等移动终端上实现抓取空中包的方法,可以利用移动终端连接无线网络的便利,无需借助pc等设备即可方便地抓取空中包。另一方面,通过部署预设服务及其与上层应用的关联,使用户输入设置参数即可抓取空中包,操作简便,用户学习成本较低,使得该方法具有较高的适用性。

应当理解的是,以上的一般描述和后文的细节描述仅是示例性和解释性的,并不能限制本公开。

附图说明

此处的附图被并入说明书中并构成本说明书的一部分,示出了符合本公开的实施方式,并与说明书一起用于解释本公开的原理。显而易见地,下面描述中的附图仅仅是本公开的一些实施方式,对于本领域普通技术人员来讲,在不付出创造性劳动的前提下,还可以根据这些附图获得其他的附图。

图1示出相关技术中抓取空中包的方法示意图;

图2示出本示例性实施方式中一种移动终端抓取空中包的方法流程图;

图3示出本示例性实施方式中一种移动终端抓取空中包的架构示意图;

图4示出本示例性实施方式中一种开始抓取空中包的交互流程图;

图5示出本示例性实施方式中一种停止抓取空中包的交互流程图;

图6示出本示例性实施方式中一种移动终端抓取空中包的装置结构框图;

图7示出本示例性实施方式中一种用于实现上述方法的计算机可读存储介质;

图8示出本示例性实施方式中一种用于实现上述方法的移动终端;

图9示出本示例性实施方式中另一种用于实现上述方法的移动终端。

具体实施方式

现在将参考附图更全面地描述示例实施方式。然而,示例实施方式能够以多种形式实施,且不应被理解为限于在此阐述的范例;相反,提供这些实施方式使得本公开将更加全面和完整,并将示例实施方式的构思全面地传达给本领域的技术人员。所描述的特征、结构或特性可以以任何合适的方式结合在一个或更多实施方式中。

相关技术的一种方案中,需要借助配置有无线网卡的pc(personalcomputer,个人电脑)来抓取空中包。如图1所示,无线设备通过无线路由器的wifi(wirelessfidelity,无线保真)信号连接到互联网,将pc的无线网卡设置为混杂模式,置于该无线路由器的wifi环境中,可以监听特定的信道,抓取无线路由器与无线设备之间传输的空中包。然而该方案需要配置额外的pc与无线网卡,使用起来较为不便,且增加了成本。

鉴于前述的各种问题,本公开的实例性实施方式提供一种移动终端抓取空中包的方法。图2示出了该方法的一种流程,可以包括步骤s210~s240:

步骤s210,获取关于抓取空中包的设置参数。

其中,设置参数是指根据需求而设定的如何抓取空中包的参数,例如可以包括:信道与带宽,表示抓取该信道中该带宽内的空中包;或者ssid,通常对应于路由器等ap(accesspoint,无线接入点)的名称,表示抓取该路由器传输的空中包;还可以包括其他类型的参数,如抓取时间、抓取的数据包总量、抓取的过滤条件等。

在一种可选的实施方式中,移动终端可以呈现一用户界面,为抓取空中包的设置界面,包含相应的选项框等,可以是系统设置界面,也可以是专门的app(application,应用程序)界面,用户在该界面内输入关于抓取空中包的设置参数。

步骤s220,将上述设置参数传输至预设服务。

本示例性实施方式中,可以事先在系统后台部署预设服务,负责抓取空中包,当用户选择开始抓取空中包后,启动该服务,从用户界面获取设置参数。在一种可选的实施方式中,该预设服务可以是android系统的原生服务(nativeservice),原生服务与前台通信后,可以直接调用系统底层的工具和资源,简化了不同组件之间的通信过程;在一种可选的实施方式中,该预设服务可以是wifiservice,wifiservice本身负责一部分无线网络配置与通信的任务,对于未覆盖到的抓取空中包的任务内容,可以事先在wifiservice中添加新的线程,从而最大限度的利用了系统原有的组件配置,节约资源。

图3示出了本示例性实施方式基于android系统的架构。如图3所示,实现了名为wifisniffer的app,其上层组件主要包括活动(activity)、活动管理器(manager)和工具类(fileutils),底层组件主要包括服务(service,即预设服务),每个组件下还包括相关的变量、函数、方法等。其中,活动可以加载激活用户界面,并在接收到各种底层指令或数据信息后,对用户界面进行相应的更新(updateui);上层和底层之间的通信是在活动管理器和服务之间实现的。基于此,在一种可选的实施方式中,步骤s220可以通过以下步骤实现:

将设置参数传输至用户界面关联的活动管理器;

通过binder将设置参数从活动管理器分发(dispatch)至预设服务。

其中,用户界面的数据信息中包含设置参数,通过活动到达活动管理器,活动管理器和服务之间通过binder通信,活动管理器将数据通过分发的方式传输到对应的服务,设置参数即对应于预设服务。

步骤s230,通过上述预设服务调用无线网络接口,以根据上述设置参数设置无线网络接口。

其中,无线网络接口负责无线连接模块与其他系统组件之间的数字通信,本示例性实施方式中,无线网络接口可以特指移动终端的无线网卡。预设服务调用无线网络接口,可以直接更改无线连接的相关设置,例如:根据设置参数设置无线连接的信道和带宽;设置连接到特定的路由器;设置连接时长;设置过滤符合特定条件的报文;将无线网络接口设置为监听模式或混杂模式,在监听模式下可以接收环境内的所有无线数据,在混杂模式下可以接收所连接的wifi中的所有无线数据,这两个模式都适合用于空中包抓取,具体采用哪个模式可以根据无线网卡的类型、所支持的模式以及实际需求而定,本公开对此不做限定。

参考上述图3举例说明,服务中包含了两个变量:mchannel和mbandwidth,表示信道和带宽,服务获取从活动管理器传输的数据后,从中提取出设置参数对这两个变量赋值,再对无线网络接口进行设置。

步骤s240,对流经无线网络接口的数据进行监听,以抓取空中包。

在完成设置后,无线网络接口除了接收目的地址为本终端的数据外,还可以接收目的地址非本终端的数据,即开始监听所设置的信道与带宽内的所有数据,从而抓取空中包。

在一种可选的实施方式中,如果步骤s210中设置的参数为ssid(即ap的名称),则预设服务可以对该ssid的无线数据或广播信息等进行解析,确定其所在的信道和带宽,从而将ssid转换为信道和带宽的设置参数,以设置无线网络接口。在解析出ssid对应的信道和带宽后,可以保存到相应的映射表中,使得系统对已经监听过的ssid无需重复解析过程,在下一次可以直接映射得到其信道和带宽等信息。

在一种可选的实施方式中,如果移动终端运行在android或其他linux内核的操作系统下,预设服务可以调用tcpdump对流经无线网络接口的数据进行监听。tcpdump是linux系统中的网络数据采集工具,可以截获网络中传送的数据包,本示例性实施方式可以将tcpdump的指令代码封装到预设服务中,通过设置tcpdump的-i参数,对无线网络接口的数据进行截获监听,过滤掉其他端口的数据。

基于上述内容,本示例性实施方式中,移动终端上获取关于抓取空中包的设置参数后,通过预设服务调用无线网络接口进行设置,以对流经无线网络接口的数据进行监听,从而抓取空中包。一方面,提供了一种在手机、平板电脑等移动终端上实现抓取空中包的方法,可以利用移动终端连接无线网络的便利,无需借助pc等设备即可方便地抓取空中包。另一方面,通过部署预设服务及其与上层应用的关联,使用户输入设置参数即可抓取空中包,操作简便,用户学习成本较低,使得该方法具有较高的适用性。

在一种可选的实施方式中,移动终端若接收到取消抓包的操作指令,则可以将无线网络接口的设置复原。其中,取消抓包指取消抓取空中包,其操作指令可以是用户输入的指令,例如在用户界面内选择取消的选项,也可以是系统自动触发的指令,例如设置抓取空中包的时间或数据量后,到达结束时间或抓取一定量的数据后自动生成取消指令。在取消抓包后,无线网络接口的设置可以复原为开始抓包前的状态,也可以复原为事先配置的默认状态,例如:取消监听的设置参数,恢复为默认的连接方式,将无线网卡的模式切换为单播模式等正常模式等等。通过自动复原的方式,可以使用户方便地在正常连接和抓取空中包的模式间一键切换,切换过程实现了用户无感知,进一步提高了操作的便利性。

图4示出本示例性实施方式中一种开始抓取空中包的交互流程图。由活动释放用户界面,用户在用户界面中输入设置参数以及开始抓取空中包的指令;活动在接收指令后,调用startsniffer()方法;然后活动管理器调用startsniffermode()方法;通过ibinder的通信,将指令传输至服务;服务通过loaddriver设置无线网络接口,并更改无线网卡的连接模式(change_connection_mode),此时开始抓取空中包。以上过程成功执行后,由服务向活动管理器反馈信息,再反馈到活动,并以此更新用户界面,例如在原用户界面中显示设置成功、开始抓取的信息,或者激活抓取空中包的监听界面等。

图5示出本示例性实施方式中一种停止抓取空中包的交互流程图。该流程与开始抓取空中包的流程相似,在已激活的用户界面中,用户输入取消抓取空中包的指令,活动在接收指令后,调用stopsniffer()方法,然后活动管理器调用stopsniffermode()方法,通过ibinder的通信,将指令传输至服务,服务退出对无线网络接口的监听(teardown_wlan_interface),并可以恢复无线网络接口的相关设置,例如无线网卡的连接模式、所连接的信道、带宽等参数。以上过程成功执行后,由服务向活动管理器反馈信息,再反馈到活动,并以此更新用户界面,例如在原用户界面中显示停止抓取的信息,或者激活wifi连接的界面等。

采用本示例性实施方式进行抓取空中包的测试,测试结果显示,在手机上同等时间长度下抓取的空中包数量和笔记本电脑上抓取的空中包数量在同一量级上,可以满足日常测试开发的使用需求。

本公开的示例性实施方式还提供了一种移动终端抓取空中包的装置,如图6所示,该装置600可以包括:参数获取模块610,用于获取关于抓取空中包的设置参数;数据传输模块620,用于将设置参数传输至预设的原生服务;无线设置模块630,用于通过原生服务调用无线网络接口,以根据设置参数设置无线网络接口;数据监听模块640,用于对流经无线网络接口的数据进行监听,以抓取空中包。

在一种可选的实施方式中,参数获取模块610,可以用于呈现一用户界面,通过用户界面获取关于抓取空中包的设置参数。

在一种可选的实施方式中,数据传输模块620,可以用于将设置参数传输至用户界面关联的活动管理器;通过binder将设置参数从活动管理器分发至预设服务。

在一种可选的实施方式中,无线设置模块630,还可以用于若接收到取消抓包的操作指令,则将无线网络接口的设置复原。

在一种可选的实施方式中,数据监听模块640,可以用于通过预设服务调用tcpdump对流经无线网络接口的数据进行监听。

在一种可选的实施方式中,无线设置模块630,还可以用于在设置无线网络接口时,将无线网络接口设置为监听模式或混杂模式。

在一种可选的实施方式中,设置参数可以包括:信道与带宽,或者服务集标识。

上述装置中各模块的具体细节在方法部分实施方式中已经详细说明,未披露的方案细节内容可以参见方法部分的实施方式内容,因而不再赘述。

所属技术领域的技术人员能够理解,本公开的各个方面可以实现为系统、方法或程序产品。因此,本公开的各个方面可以具体实现为以下形式,即:完全的硬件实施方式、完全的软件实施方式(包括固件、微代码等),或硬件和软件方面结合的实施方式,这里可以统称为“电路”、“模块”或“系统”。

本公开的示例性实施方式还提供了一种计算机可读存储介质,其上存储有能够实现本说明书上述方法的程序产品。在一些可能的实施方式中,本公开的各个方面还可以实现为一种程序产品的形式,其包括程序代码,当程序产品在终端设备上运行时,程序代码用于使终端设备执行本说明书上述“示例性方法”部分中描述的根据本公开各种示例性实施方式的步骤。

参考图7所示,描述了根据本公开的示例性实施方式的用于实现上述方法的程序产品700,其可以采用便携式紧凑盘只读存储器(cd-rom)并包括程序代码,并可以在终端设备,例如个人电脑上运行。然而,本公开的程序产品不限于此,在本文件中,可读存储介质可以是任何包含或存储程序的有形介质,该程序可以被指令执行系统、装置或者器件使用或者与其结合使用。

程序产品可以采用一个或多个可读介质的任意组合。可读介质可以是可读信号介质或者可读存储介质。可读存储介质例如可以为但不限于电、磁、光、电磁、红外线、或半导体的系统、装置或器件,或者任意以上的组合。可读存储介质的更具体的例子(非穷举的列表)包括:具有一个或多个导线的电连接、便携式盘、硬盘、随机存取存储器(ram)、只读存储器(rom)、可擦式可编程只读存储器(eprom或闪存)、光纤、便携式紧凑盘只读存储器(cd-rom)、光存储器件、磁存储器件、或者上述的任意合适的组合。

计算机可读信号介质可以包括在基带中或者作为载波一部分传播的数据信号,其中承载了可读程序代码。这种传播的数据信号可以采用多种形式,包括但不限于电磁信号、光信号或上述的任意合适的组合。可读信号介质还可以是可读存储介质以外的任何可读介质,该可读介质可以发送、传播或者传输用于由指令执行系统、装置或者器件使用或者与其结合使用的程序。

可读介质上包含的程序代码可以用任何适当的介质传输,包括但不限于无线、有线、光缆、rf等等,或者上述的任意合适的组合。

可以以一种或多种程序设计语言的任意组合来编写用于执行本公开操作的程序代码,程序设计语言包括面向对象的程序设计语言—诸如java、c++等,还包括常规的过程式程序设计语言—诸如“c”语言或类似的程序设计语言。程序代码可以完全地在用户计算设备上执行、部分地在用户设备上执行、作为一个独立的软件包执行、部分在用户计算设备上部分在远程计算设备上执行、或者完全在远程计算设备或服务器上执行。在涉及远程计算设备的情形中,远程计算设备可以通过任意种类的网络,包括局域网(lan)或广域网(wan),连接到用户计算设备,或者,可以连接到外部计算设备(例如利用因特网服务提供商来通过因特网连接)。

本公开的示例性实施方式还提供了一种能够实现上述方法的移动终端。如图8所示,该移动终端800可以包括:处理器810;存储器820,用于存储处理器810的可执行指令;无线网络接口830。其中,无线网络接口830用于传输无线数据,为监听无线数据的必需组件,处理器810配置为经由执行上述可执行指令来执行上述任一种抓取空中包的方法。

在一种可选的实施方式中,如图9所示,移动终端900可以以通用计算设备的形式表现。移动终端900的组件可以包括但不限于:上述至少一个处理单元910、上述至少一个存储单元920、连接不同系统组件(包括存储单元920和处理单元910)的总线930、显示单元940和无线网络接口970。

存储单元920存储有程序代码,程序代码可以被处理单元910执行,使得处理单元910执行本说明书上述“示例性方法”部分中描述的根据本公开各种示例性实施方式的步骤。例如,处理单元910可以执行图2所示的方法步骤等。

存储单元920可以包括易失性存储单元形式的可读介质,例如随机存取存储单元(ram)921和/或高速缓存存储单元922,还可以进一步包括只读存储单元(rom)923。

存储单元920还可以包括具有一组(至少一个)程序模块925的程序/实用工具924,这样的程序模块925包括但不限于:操作系统、一个或者多个应用程序、其它程序模块以及程序数据,这些示例中的每一个或某种组合中可能包括网络环境的实现。

总线930可以为表示几类总线结构中的一种或多种,包括存储单元总线或者存储单元控制器、外围总线、图形加速端口、处理单元或者使用多种总线结构中的任意总线结构的局域总线。

移动终端900也可以与一个或多个外部设备1000(例如键盘、指向设备、蓝牙设备等)通信,还可与一个或者多个使得用户能与该移动终端900交互的设备通信,和/或与使得该移动终端900能与一个或多个其它计算设备进行通信的任何设备(例如路由器、调制解调器等等)通信。这种通信可以通过输入/输出(i/o)接口950进行。并且,移动终端900还可以通过网络适配器960与一个或者多个网络(例如局域网(lan),广域网(wan)和/或公共网络,例如因特网)通信。如图所示,网络适配器960通过总线930与移动终端900的其它模块通信。应当明白,尽管图中未示出,可以结合移动终端900使用其它硬件和/或软件模块,包括但不限于:微代码、设备驱动器、冗余处理单元、外部磁盘驱动阵列、raid系统、磁带驱动器以及数据备份存储系统等。

通过以上的实施方式的描述,本领域的技术人员易于理解,这里描述的示例实施方式可以通过软件实现,也可以通过软件结合必要的硬件的方式来实现。因此,根据本公开实施方式的技术方案可以以软件产品的形式体现出来,该软件产品可以存储在一个非易失性存储介质(可以是cd-rom,u盘,移动硬盘等)中或网络上,包括若干指令以使得一台计算设备(可以是个人计算机、服务器、终端装置、或者网络设备等)执行根据本公开示例性实施方式的方法。

此外,上述附图仅是根据本公开示例性实施方式的方法所包括的处理的示意性说明,而不是限制目的。易于理解,上述附图所示的处理并不表明或限制这些处理的时间顺序。另外,也易于理解,这些处理可以是例如在多个模块中同步或异步执行的。

应当注意,尽管在上文详细描述中提及了用于动作执行的设备的若干模块或者单元,但是这种划分并非强制性的。实际上,根据本公开的示例性实施方式,上文描述的两个或更多模块或者单元的特征和功能可以在一个模块或者单元中具体化。反之,上文描述的一个模块或者单元的特征和功能可以进一步划分为由多个模块或者单元来具体化。

本领域技术人员在考虑说明书及实践这里公开的发明后,将容易想到本公开的其他实施方式。本申请旨在涵盖本公开的任何变型、用途或者适应性变化,这些变型、用途或者适应性变化遵循本公开的一般性原理并包括本公开未公开的本技术领域中的公知常识或惯用技术手段。说明书和实施方式仅被视为示例性的,本公开的真正范围和精神由权利要求指出。

应当理解的是,本公开并不局限于上面已经描述并在附图中示出的精确结构,并且可以在不脱离其范围进行各种修改和改变。本公开的范围仅由所附的权利要求来限。

当前第1页1 2 
网友询问留言 已有0条留言
  • 还没有人留言评论。精彩留言会获得点赞!
1