SOCK_RAW 写一个简单的网络嗅探器

2024-01-09 21:08
文章标签 简单 网络 sock raw 嗅探器

本文主要是介绍SOCK_RAW 写一个简单的网络嗅探器,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

之前有一篇写UDP反射放大攻击的
为什么IP头和UDP头可以伪造,看下面的TCP自己想一想就知道了
一般情况下我们使用的都是封装好的TCP或UDP协议。但事实上我们可以自己封装和解析。
注意:SOCK_RAW 程序必须有管理员权限

简单实现代码

/*
通常的套接字只能响应与自己MAC地址相匹配的或是以广播行事发出的数据帧。
对于其他形式的数据帧网路接口采取的动作是直接丢弃。为了使网卡接收所有经过它的封包,
要将其设为混杂模式。在用户模式下,对网卡混杂模式的设置是通过原始套接字来实现的。创建原始套接字之后,将它绑定到一个明确的本地地址,然后向套接字发送SIO_RCVALL控制命令,让它接收所有的IP包,这样网卡便进入了混杂模式。*/#include "pch.h"
#include <iostream>
#include <WinSock2.h>
#include <ws2ipdef.h>
#include <mstcpip.h> //SIO_RCVALL
#include <process.h>
#pragma warning(disable:4996)
#pragma comment(lib,"ws2_32.lib")typedef struct _IPHeader {u_char VIHL; //版本和首部长度 各占4bitu_char ToS; //服务类型u_short TotalLen; //总长度u_short ID; //标识号u_short Frag_Flags; //片偏移量u_char TTL; //生存时间u_char Protocol; //协议u_short Checksum; //首部校验和//ULONG SrcIP;//ULONG DestIP;struct in_addr SrcIP; //源IP地址struct in_addr DestIP; //目的地址
}IPHDR, *PIPHDR;/*TCP头*/
typedef struct _tcpheader {USHORT sourcePort; //来源端口USHORT destinationPort;//目标端口ULONG sequenceNumber; // 32位序列号ULONG acknowledgeNumber; //32位确认号//下面2个 共占16位UCHAR dataOffset;//4位首部长度/6位保留字UCHAR flags;//6位标志位USHORT windows;//16位窗口大小USHORT checksum;//16位校验和USHORT urgentPointer;//16位紧急数据偏移量}TCP_HDR, *PTCP_HDR;//解析TCP封包
void DecodeTCPPacket(char* pData) {PTCP_HDR pTcphdr = (PTCP_HDR)pData;//取出端口printf_s("Port: %d -> %d \n", ntohs(pTcphdr->sourcePort), ntohs(pTcphdr->destinationPort));//下面还可以根据端口进一步解析应用层协议:switch (ntohs(pTcphdr->destinationPort)) {case 80: {printf_s("这是一个80端口 具体信息:%s\n", pData+sizeof(TCP_HDR));break;}case 21: {printf_s("这是一个21端口 具体信息:%s\n", pData + sizeof(TCP_HDR));break;}case 8080: {printf_s("这是一个8080端口 具体信息:%s\n", pData + sizeof(TCP_HDR));break;}}
}//解析IP封包
void DecodeIPPacket(char * pData) {PIPHDR pIphdr = (PIPHDR)pData;char szSourceIP[32] = { 0 }, szDestIP[32] = {0};printf_s("---------------------\n");//从IP头中取出源IP地址和目的IP地址strcpy_s(szSourceIP, inet_ntoa(pIphdr->SrcIP));strcpy_s(szDestIP, inet_ntoa(pIphdr->DestIP));printf_s("%s -> %s \n", szSourceIP, szDestIP);//IP头长度//因为IP头 版本号和首部长度各占4位,先取低4位长度//IP头我们封装的时候是这样://pIphdr->VIHL = (4 << 4 | (sizeof(IPHDR) / sizeof(ULONG)));int nHeaderLen = (pIphdr->VIHL & 0xf) * sizeof(ULONG);switch (pIphdr->Protocol) {case IPPROTO_TCP:{//解析TCP封包DecodeTCPPacket(pData + nHeaderLen);break;}case IPPROTO_UDP:{break;}case IPPROTO_ICMP:{break;}}
}int main()
{WSADATA wsaData;WSAStartup(MAKEWORD(2, 2), &wsaData);SOCKET s = socket(AF_INET, SOCK_RAW, IPPROTO_IP);if (s == INVALID_SOCKET) {printf_s("请管理员运行\n");return -1;}//获取本地IP地址char szHostName[56];SOCKADDR_IN sin;struct hostent* pHost;gethostname(szHostName,56);if( (pHost=gethostbyname((char*)szHostName)) == NULL){printf_s("gethostbyname失败\n");return -1;}sin.sin_family = AF_INET;sin.sin_port = htons(0);//因为我有一大堆网卡,所以我这里是第三个是我需要的for (ULONG i = 0; pHost->h_addr_list[i] + pHost->h_length < pHost->h_name;) {printf_s("我的IP[%d]:%s\n", ++i , inet_ntoa(*((in_addr *)pHost->h_addr_list[i])));}memcpy_s(&sin.sin_addr.S_un.S_addr, 4U, pHost->h_addr_list[3], pHost->h_length);printf_s("准备绑定到IP:%s\n", inet_ntoa(sin.sin_addr));//在调用ioctl之前,套接字必须绑定if (bind(s, (sockaddr*)&sin, sizeof(sin)) == SOCKET_ERROR){printf_s("Bind失败\n");return -1;}//设置SIO_RCVALLDWORD dwValue = 1;if (ioctlsocket(s, SIO_RCVALL, &dwValue) != 0) {printf_s("SIO_RCVALL 失败\n");return -1;}//开始接收封包char buff[1024];int nRet;while (TRUE) {nRet = recv(s, buff, 1024, 0);if (nRet > 0) {//解析IP封包DecodeIPPacket(buff);}}closesocket(s);WSACleanup();
}

这篇关于SOCK_RAW 写一个简单的网络嗅探器的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/588436

相关文章

一份LLM资源清单围观技术大佬的日常;手把手教你在美国搭建「百万卡」AI数据中心;为啥大模型做不好简单的数学计算? | ShowMeAI日报

👀日报&周刊合集 | 🎡ShowMeAI官网 | 🧡 点赞关注评论拜托啦! 1. 为啥大模型做不好简单的数学计算?从大模型高考数学成绩不及格说起 司南评测体系 OpenCompass 选取 7 个大模型 (6 个开源模型+ GPT-4o),组织参与了 2024 年高考「新课标I卷」的语文、数学、英语考试,然后由经验丰富的判卷老师评判得分。 结果如上图所

【Altium】查找PCB上未连接的网络

【更多软件使用问题请点击亿道电子官方网站】 1、文档目标: PCB设计后期检查中找出没有连接的网络 应用场景:PCB设计后期,需要检查是否所有网络都已连接布线。虽然未连接的网络会有飞线显示,但是由于布线后期整板布线密度较高,虚连,断连的网络用肉眼难以轻易发现。用DRC检查也可以找出未连接的网络,如果PCB中DRC问题较多,查找起来就不是很方便。使用PCB Filter面板来达成目的相比DRC

通信系统网络架构_2.广域网网络架构

1.概述          通俗来讲,广域网是将分布于相比局域网络更广区域的计算机设备联接起来的网络。广域网由通信子网于资源子网组成。通信子网可以利用公用分组交换网、卫星通信网和无线分组交换网构建,将分布在不同地区的局域网或计算机系统互连起来,实现资源子网的共享。 2.网络组成          广域网属于多级网络,通常由骨干网、分布网、接入网组成。在网络规模较小时,可仅由骨干网和接入网组成

Toolbar+DrawerLayout使用详情结合网络各大神

最近也想搞下toolbar+drawerlayout的使用。结合网络上各大神的杰作,我把大部分的内容效果都完成了遍。现在记录下各个功能效果的实现以及一些细节注意点。 这图弹出两个菜单内容都是仿QQ界面的选项。左边一个是drawerlayout的弹窗。右边是toolbar的popup弹窗。 开始实现步骤详情: 1.创建toolbar布局跟drawerlayout布局 <?xml vers

回调的简单理解

之前一直不太明白回调的用法,现在简单的理解下 就按这张slidingmenu来说,主界面为Activity界面,而旁边的菜单为fragment界面。1.现在通过主界面的slidingmenu按钮来点开旁边的菜单功能并且选中”区县“选项(到这里就可以理解为A类调用B类里面的c方法)。2.通过触发“区县”的选项使得主界面跳转到“区县”相关的新闻列表界面中(到这里就可以理解为B类调用A类中的d方法

自制的浏览器主页,可以是最简单的桌面应用,可以把它当成备忘录桌面应用

自制的浏览器主页,可以是最简单的桌面应用,可以把它当成备忘录桌面应用。如果你看不懂,请留言。 完整代码: <!DOCTYPE html><html lang="zh-CN"><head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><ti

python实现最简单循环神经网络(RNNs)

Recurrent Neural Networks(RNNs) 的模型: 上图中红色部分是输入向量。文本、单词、数据都是输入,在网络里都以向量的形式进行表示。 绿色部分是隐藏向量。是加工处理过程。 蓝色部分是输出向量。 python代码表示如下: rnn = RNN()y = rnn.step(x) # x为输入向量,y为输出向量 RNNs神经网络由神经元组成, python

宝塔面板部署青龙面板教程【简单易上手】

首先,你得有一台部署了宝塔面板的服务器(自己用本地电脑也可以)。 宝塔面板部署自行百度一下,很简单,这里就不走流程了,官网版本就可以,无需开心版。 首先,打开宝塔面板的软件商店,找到下图这个软件(Docker管理器)安装,青龙面板还是安装在docker里,这里依赖宝塔面板安装和管理docker。 安装完成后,进入SSH终端管理,输入代码安装青龙面板。ssh可以直接宝塔里操作,也可以安装ssh连接

XMG Quartz2D的简单使用

// //  Quratz2DView.m //  Quartz2D // //  Created by 王宁 on 16/5/6. //  Copyright © 2016年 ylshmacmini. All rights reserved. // #import "Quratz2DView.h" //Quartz@2D是一个二维绘图引擎,同时支

网页脚本输入这么简单

如何在网页中进行脚本操作呢? 研究了一下,很简单,用google浏览器的Console直接操作javaScript。思路: Created with Raphaël 2.1.0 开始 输入(如何输入) 点击(如何点击) 结束 下面是,通过脚本刷直播屏的实现,直接在Console输入即可 var words=new Arra