通过数据包识别应用程序

通过分析数据包是否可以识别特定的应用程序?如果可以,数据包的哪些属性可以帮助唯一地识别一个应用程序?任何帮助都将不胜感激。


回答:

这个问题涉及的范围非常广泛,如果你能提出解决方案,你应该申请专利。你可以根据数据包和协议来推断应用程序的知识,但规则并不在100%的情况下都适用。以下是一些你需要知道的考虑因素(这不是一个完整的列表,但它们可以给你一些想法):

  • 根据源端口或目标端口,你可以获取关于在两个节点之一运行的应用程序的信息。例如,默认情况下,Web服务器使用80或8080端口(或使用HTTPS的443端口)。默认情况下,SSH使用22端口。然而,一个应用程序可以被配置为监听不同的端口。另外,许多不同的应用程序通过80、8080、443端口使用HTTP进行通信。在后一种情况下,协议可能是HTTP,但你无法确定它是哪个应用程序。
  • 如果通信未加密,你可以通过嗅探数据包负载获取信息。但如果通信通过SSL,例如,除非你实施中间人攻击,否则没有办法做到这一点。
  • 如果你有权访问一台机器,使用netstat或其他工具,你可以根据它使用的端口来识别一个应用程序。
  • 另一种猜测应用程序的方式(更像是猜测而不是确定性的)是通过分析通信模式。

简而言之,基于网络分析,你可以对应用程序进行猜测。然而,没有一种方法可以100%准确地告诉你答案。

Related Posts

L1-L2正则化的不同系数

我想对网络的权重同时应用L1和L2正则化。然而,我找不…

使用scikit-learn的无监督方法将列表分类成不同组别,有没有办法?

我有一系列实例,每个实例都有一份列表,代表它所遵循的不…

f1_score metric in lightgbm

我想使用自定义指标f1_score来训练一个lgb模型…

通过相关系数矩阵进行特征选择

我在测试不同的算法时,如逻辑回归、高斯朴素贝叶斯、随机…

可以将机器学习库用于流式输入和输出吗?

已关闭。此问题需要更加聚焦。目前不接受回答。 想要改进…

在TensorFlow中,queue.dequeue_up_to()方法的用途是什么?

我对这个方法感到非常困惑,特别是当我发现这个令人费解的…

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注