首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

原始套接 IP_HDRINCL 转

原始套接可以访问ICMP和ICMP等协议包,可以读写内核不处理的IP数据包。可以创建自定义的IP数据包首部。一句话,使用原始套接可以   编写基于IP协议的通讯程序。   ...IP协议第二个参数:SOCKET类型第三个参数:协议类型注意:@如果指定协议为0时,原始套接可以接收内核传递给原始套接的任何IP数据包,且只有超级用户才可以创建原始套接。   ...@当需要编写自己的IP数据包首部时,可以在原始套接上设置套接选项IP_HDRINCL.在不设置这个选项的情况下,IP协议自动填充IP数据包的首部。   ...2.大多数ICMP数据包的一个拷贝传送给匹配的原始套接。   3.内核处理的所有其它类型的数据包的一个拷贝都传给匹配的原始套接。   ...在一个IP数据包传送给原始套接之前,内核需要选择匹配的原始套接1.数据包的协议域必须与接收原始套接的协议类型匹配。

2.4K10
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    原始套接和流量嗅探

    ---- 原始套接和流量嗅探 前言 《Python黑帽子:黑客与渗透测试编程之道》的读书笔记,会包括书中源码,并自己将其中一些改写成Python3版本。...书是比较老了,anyway,还是本很好的书 本篇是第3章原始套接和流量嗅探 1、Windows和Linux上的包嗅探 为了多平台使用,先创建SOCKET,再判断平台 windows允许嗅探所有协议 linux...coding:utf8 -*- import socket import os # 监听主机,即监听那个网络接口,下面的为我的kali的ip host = "10.10.10.145" # 创建原始套接...socket.IPPROTO_ICMP sniffer = socket.socket(socket.AF_INET, socket.SOCK_RAW, socket_protocol) #raw的中文是生的意思,大概就是原始套接的意思吧...self.protocol_num] except: self.protocol = str(self.protocol_num) # 下面的代码类似于之前的例子 # 创建原始套接

    1.8K20

    Go中原始套接的深度实践

    介绍 原始套接(raw socket)是一种网络套接,允许直接发送/接收更底层的数据包而不需要任何传输层协议格式。...平常我们使用较多的套接(socket)都是基于传输层,发送/接收的数据包都是不带TCP/UDP等协议头部的。...当使用套接发送数据时,传输层在数据包前填充上面格式的协议头部数据,然后整个发送到网络层,接收时去掉协议头部,把应用数据抛给上层。...如果想自己封装头部或定义协议的话,就需要使用原始套接,直接向网络层发送数据包。 为了便于后面理解,这里统一称应用数据为 payload,协议头部为 header,套接为socket。...表示服务器之间的网络通信 syscall.AF_UNIX表示同一台机器上的进程通信 syscall.AF_INET6表示以IPv6的方式进行服务器之间的网络通信 其他 第二个参数 syscall.SOCK_RAW,表示使用原始套接

    3K20

    CC++ 原生套接抓取FTP数据包

    本文深入介绍基于原始套接的网络数据包捕获与分析工具,通过实时监控网络流量,实现抓取流量包内的FTP通信数据,并深入了解数据传输的细节,捕捉潜在的网络问题以及进行安全性分析。...原始套接是一种底层的网络编程方式,允许程序直接访问网络协议栈,无需操作系统进行任何处理。在Windows平台,可以通过SOCK_RAW套接类型来创建原始套接。...本文的代码示例基于Winsock2库实现,允许我们以最底层的方式捕获网络数据包。 Winsock2库与套接初始化 在使用原始套接之前,我们首先需要初始化Winsock2库。...校验和字段用于检测数据包的完整性。 创建原始套接 使用socket函数创建原始套接,指定协议为IPPROTO_IP,表示接收所有的IP包。...= 0) return -1; // 创建原始套接,过滤IP数据包 SOCKET SockRaw = socket(AF_INET, SOCK_RAW, IPPROTO_IP);

    35410

    《Python黑帽子》:原始套接和流量嗅探

    在本文中,我们将使用原始套接来访问诸如IP 和ICMP 头等底层的网络信息。在下面的例子中,我们只对IP 层和更高层感兴趣,因此我们不会去解码以太网头中的信息。...Windows 和Linux 上的包嗅探 在Windows 和Linux 上访问原始套接有些许不同,但我们更中意于在多平台部署同样的嗅探器以实现更大的灵活性。...我们先创建套接对象,然后再判断程序在哪个平台上运行。在Windows 平台上,我们需要通过套接输入/输出控制(IOCTL)1设置一些额外的标志,它允许在网络接口上启用混杂模式。...在第一个例子中,我们只需设置原始套接嗅探器,读取一个数据包,然后退出即可。 首先,我们通过构建套接对象对网络接口上的数据包嗅探进行必要的参数设置①。...如果你是在Linux 上运行的这段代码,那么你接收到nostarch.com 的ICMP 响应包。仅嗅探一个数据包并没有多少实际用处,因此,我们添加一些功能来处理更多的数据包并解码其中的内容。

    1.3K20

    Linux网络套接(二)

    返回值:返回一个新的套接描述符。...首先是写出服务器的代码,代码的思路是这样的: ①首先为服务器创建套接,因为这个是TCP协议,TCP是面向连接的,因此服务器是需要进入监听状态才能让客户端连接,所以使用socket接口创建出来的套接是属于监听套接...=2) { Usage(argv[0]); return 1; } //tcp_server //1.创建套接,此套接为监听套接,用于绑定和监听 int listen_sock...=2) { Usage(argv[0]); return 1; } //tcp_server //1.创建套接,此套接为监听套接,用于绑定和监听 int listen_sock...=2) { Usage(argv[0]); return 1; } //tcp_server //1.创建套接,此套接为监听套接,用于绑定和监听 int listen_sock

    1.9K30

    Linux网络-套接编程基础

    Linux网络编程套接 零、前言 一、网络基础知识 1、源IP地址和目的IP地址 2、源MAC地址和目的MAC地址 3、认识端口号 4、PORT VS PID 5、TCP和UDP协议 6、网络字节序...二、socket编程接口 1、sockaddr结构 2、socket 常见API 零、前言 本章就Linux网络编程进行概念及接口学习,下一篇则是简单的进行上手网络套接编程 一、网络基础知识 1...、源IP地址和目的IP地址 在数据传输时各网络协议栈会对数据进行报头封装,而在IP数据包头部中, 有两个IP地址, 分别叫做源IP地址, 和目的IP地址 网络中每台计算机都有一个唯一的IP地址,也就是说网络中用...结构 套接不仅支持跨网络的进程间通信,还支持本地的进程间通信(域间套接) 因此套接提供了sockaddr_in结构体和sockaddr_un结构体,其中sockaddr_in结构体是用于跨网络通信的...,而sockaddr_un结构体是用于本地通信的 为了让套接的网络通信和本地通信能够使用同一套函数接口,于是就出现了sockeaddr结构体,该结构体与sockaddr_in和sockaddr_un的结构都不相同

    1.4K20

    Linux网络-TCPUDP套接编程

    零、前言 本章主要是对套接网络编程的一个学习,目标是能够基本的进行套接编程 一、UDP套接 1、创建套接 无论是服务端还是客户端,进行网络编程需要做的第一件事就是创建套接 socket...使用命令行参数+网络字节序转化接口 local.sin_addr.s_addr=htons(INADDR_ANY);//云服务器不建议绑定明确的ip,建议使用INADDR_ANY绑定该主机所有设备 //网络文件与套接进行绑定...+网络字节序转化 local.sin_addr.s_addr=htons(INADDR_ANY);//云服务器不建议绑定明确的ip,建议使用INADDR_ANY绑定该主机所有设备 //网络文件与套接进行绑定...;小于0,则表示读取时遇到了错误 注:如果客户端连接关闭了,那么此时服务端套接当中的信息读完后就会读取到0,不必再为该客户端提供服务了 write函数原型: ssize_t write(int...fd, const void *buf, size_t count); 解释: fd:特定的文件描述符,表示数据写入该文件描述符对应的套接 buf:需要写入的数据 count:需要写入数据的字节个数

    3.7K10

    Linux】网络基础+UDP网络套接编程

    地址确认出数据包的下一跳位置,所以数据包首先要进行以太网协议层的解包分用,数据包交付给网络层的路由器,路由器会通过自己的路由表确定出数据包要发送的主机的ip地址,然后再向下进行封装,数据包向下交付给指定...套接编程中,常见的有网络套接编程,原始套接编程,unix域间套接编程。 网络套接支持多主机跨网络通信,下面讲到的都是这个套接编程。...原始套接比较难,它可以绕过传输层直接访问网络层以及下面的层,抓包和网络监测工具就是通过原始套接来完成的,文章不谈论原始套接和unix域间套接,只谈论网络套接编程。...unix域间套接只能进行本地通信,无法进行网络通信,这个套接只要在学习网络套接过后,找篇unix域间套接的相关源代码一看就能懂了。 3....第一个参数代表你创建套接的域,是用inet网络套接通信呢?又或是用unix域间套接通信呢?

    37310

    Linux进程通信之Unix套接(一)

    Linux进程通信之Unix套接(一) 什么是套接 所谓套接(Socket),就是对网络中不同主机上的应用进程之间进行双向通信的端点的抽象。...一个套接就是网络上进程通信的一端,提供了应用层进程利用网络协议交换数据的机制。...) AF_INET6(IPV6) AF_UNIX(本地通讯协议,一般用于进程通信,不需要经过网卡) 套接类型 流套接(SOCK_STREAM),提供一个顺序化的、可靠的、全双工的、基于连接的字节流。...TCP 协议即基于这种流式套接。 数据报套接(SOCK_DGRAM)即提供数据报文的支持。(无连接,不可靠、固定最大长度).UDP协议即基于这种数据报文套接。...原始套接(SOCK_RAW)即提供读取原始的网络协议。这种特殊的套接可用于手工构建任意类型的协议。一般使用这个套接来实现 ICMP 请求(例如 ping)。

    2.7K30

    Linux内核编程--网络协议与套接编程

    类型描述SOCK_DGRAM数据报套接SOCK_RAW原始套接SOCK_SEQPACKET有序分组套接SOCK_STREAM字节流套接 --protocol参数:选择所给定domain和type...套接与地址关联--bind() bind()操作把一个本地协议地址和一个套接进行了绑定,为了方便客户端根据地址找到服务器的位置。...如果调用connect()或listen(),但没有地址绑定到套接上,系统会选一个默认地址去绑定。 套接地址的获得: a.可以调用getsockname()来发现绑定到套接上的地址。...监听套接--listen() 仅在套接协议为TCP时调用listen(),调用listen()导致套接从CLOSED状态变为LISTEN状态。...https://www.binarytides.com/socket-programming-c-linux-tutorial/

    2.1K20

    浅谈原始套接 SOCK_RAW 的内幕及其应用(port scan, packet sniffer, syn flood, icmp flood)

    真正从网卡进来的数据是完整的以太网帧,底层用sk_buff 数据结构描述,最终进入接收缓冲区recv buffer,而我们应用层调用read / recv /recvfrom 从接收缓冲区拷贝数据到应用层提供的buffer,对一般的套接...0 , &saddr , &saddr_size);     //Now process the packet     ProcessPacket(buffer , data_size); } 即创建原始套接...Error message : %s \n" , errno , strerror(errno));         exit(0);     } } 创建一个原始套接s,开启IP_HDRINCL 选项...另开一个线程创建另一个原始套接,仿照packet sniffer 进行数据包的接收,分解tcp 头部看是否syn == 1 && ack == 1 && dest_addr == src_addr,...如果不追求效率,很简单的做法是直接用普通的套接,循环端口去connect,成功就表明端口是打开的,只是三次握手完整了一回。

    3.6K00

    图解 | 深入揭秘Linux 接收网络数据包

    大家好,我是「云舒编程」,今天我们来聊聊Linux是怎么从网络上接收数据包的。...本文继续介绍「数据包怎么从网线到进程,在被应用程序使用」。...通过本文你可学到: Linux 是怎么发送数据包到网络上的 Linux 是怎么从网络上接收数据包的 软中断、硬中断 Linux 是怎么从网络上接收数据包的 整体流程: 系统初始化时,网卡驱动程序会向内核申请一块内存...如果你发现你的 Linux 软中断 CPU 消耗都集中在一个核 上的话,做法是要把调整硬中断的CPU亲和性,来硬中断打散到不同的 CPU 核上去。...dev_scratch; }; }; struct list_head list; //指向头节点 }; union { struct sock *sk; //报文所属的套接

    99411

    raw socket是啥(一)?

    raw socket用于接收原始数据包。这意味着在Ethernet层接收到的数据包直接传递到raw socke。...准确地说,原始套接绕过正常的 TCP/IP 处理并将数据包发送到特定的用户应用程序(参见图 1)。...其他套接(例如stream sockets 和data gram sockets)从传输层接收数据,该数据不包含headers ,仅包含payload。这意味着没有关于源IP地址和MAC地址的信息。...原始套接允许应用程序直接访问较低级别的协议,这意味着原始套接接收未提取的数据包(参见图 2)。与流和数据报套接的情况不同,无需向原始套接提供端口和 IP 地址。...如果我们对不同网络层的标头的内容或结构感兴趣,我们可以借助数据包嗅探器来访问它们。有多种适用于 Linux数据包嗅探器,例如 Wireshark。

    1.5K40

    linux网络编程之socket(十五):UNIX域套接编程和socketpair 函数

    UNIX域套接与TCP套接相比较,在同一台主机的传输速度前者是后者的两倍。这是因为,IPC机制本质上是可靠的通讯,而网络协议是为不可靠的通讯设计的。...UNIX Domain Socket也提供面向流和面向数据包两种API接口,类似于TCP和UDP,但是面向消息的UNIX Domain Socket也是可靠的,消息既不会丢失也不会顺序错乱。...三、UNIX域套接编程注意点 1、bind成功将会创建一个文件,权限为0777 & ~umask 2、sun_path最好用一个绝对路径 3、UNIX域协议支持流式套接口与报式套接口 4、UNIX...域流式套接connect发现监听队列满时,会立刻返回一个ECONNREFUSED,这和TCP不同,如果监听队列满,会忽略到来的SYN,这导致对方重传SYN。...即父进程持有sockfds[0] 套接进行读写,而子进程持有sockfds[1] 套接进行读写。 参考: 《Linux C 编程一站式学习》 《TCP/IP详解 卷一》 《UNP》

    3.4K00
    领券