c语言中的Openflow包解析

c语言中的Openflow包解析,c,openflow,C,Openflow,我有一个关于openflow包编程的问题。我建立了一个openflow网络,通过wireshark捕获控制器和交换机之间的数据包,并将其保存在pcap文件中。现在我想在C程序中读取这个文件,并分析openflow控制的数据包头。我认为一种解决方案是逐字节读取文件并分离openflow数据包,但这似乎不是一种有用的方法。所以我的问题是:有没有像C语言中的pcap这样的特殊库来提供一些工具来读取openflow数据包的头并使用它们?例如,为了进一步解决我的问题,我可以使用libpcap轻松找到包含这

我有一个关于openflow包编程的问题。我建立了一个openflow网络,通过wireshark捕获控制器和交换机之间的数据包,并将其保存在pcap文件中。现在我想在C程序中读取这个文件,并分析openflow控制的数据包头。我认为一种解决方案是逐字节读取文件并分离openflow数据包,但这似乎不是一种有用的方法。所以我的问题是:有没有像C语言中的pcap这样的特殊库来提供一些工具来读取openflow数据包的头并使用它们?例如,为了进一步解决我的问题,我可以使用libpcap轻松找到包含这些指令的数据包的MAC地址

.........
#include "pcap.h"
.........
pcap_t* descr;
const u_char *packet;
struct pcap_pkthdr hdr;     /* pcap.h */
struct ether_header *eptr;  /* net/ethernet.h */
u_char* args = NULL;
u_char *ptr; /* printing out hardware header info */
..........
..........
/* grab a device to peak into... */
dev = pcap_lookupdev(errbuf);

descr = pcap_open_live(dev,BUFSIZ,0,-1,errbuf);
// we will get the packet here from the interface
packet = pcap_next(descr,&hdr);
if(packet == NULL)
{
    printf("Didn't grab packet\n");
    exit(1);
}
 eptr = (struct ether_header *) packet;
ptr = eptr->ether_dhost;
i = ETHER_ADDR_LEN;
printf(" Source Address:  ");
do{
    printf("%s%x",(i == ETHER_ADDR_LEN) ? " " : ":",*ptr++);
}while(--i>0);

所以我想知道,有没有这样的方法来查找Openflow数据包头?

我使用pcap库来获取一些头信息,以决定将数据包路由到哪里。如果您真的想剖析Openflow消息,我建议您下载。您还可以找到源代码,在那里您可以适应您的需求