通过分析数据包是否可以识别特定的应用程序?如果可以,数据包的哪些属性可以帮助唯一地识别一个应用程序?任何帮助都将不胜感激。
回答:
这个问题涉及的范围非常广泛,如果你能提出解决方案,你应该申请专利。你可以根据数据包和协议来推断应用程序的知识,但规则并不在100%的情况下都适用。以下是一些你需要知道的考虑因素(这不是一个完整的列表,但它们可以给你一些想法):
- 根据源端口或目标端口,你可以获取关于在两个节点之一运行的应用程序的信息。例如,默认情况下,Web服务器使用80或8080端口(或使用HTTPS的443端口)。默认情况下,SSH使用22端口。然而,一个应用程序可以被配置为监听不同的端口。另外,许多不同的应用程序通过80、8080、443端口使用HTTP进行通信。在后一种情况下,协议可能是HTTP,但你无法确定它是哪个应用程序。
- 如果通信未加密,你可以通过嗅探数据包负载获取信息。但如果通信通过SSL,例如,除非你实施中间人攻击,否则没有办法做到这一点。
- 如果你有权访问一台机器,使用netstat或其他工具,你可以根据它使用的端口来识别一个应用程序。
- 另一种猜测应用程序的方式(更像是猜测而不是确定性的)是通过分析通信模式。
简而言之,基于网络分析,你可以对应用程序进行猜测。然而,没有一种方法可以100%准确地告诉你答案。