Linux软件高级编程-网络--day12

1.recvfrom

ssize_t recvfrom(int sockfd, void *buf, size_t len, int flags,

struct sockaddr *src_addr, socklen_t *addrlen);

功能:

从套接字中接收数据

参数:

sockfd:套接字文件描述符

buf:存放数据空间首地址

flags:属性 默认为0

src_addr:存放IP地址信息的空间首地址

addrlen:存放接收到IP地址大小空间的首地址

返回值:

成功返回实际接收字节数

失败返回-1

2.修改虚拟机到桥接模式:

点击"虚拟机"

点击"设置"

点击"网络适配器"

选择"桥接模式"

点击"确定"

3.将网卡桥接到无线网卡

点击"编辑"

点击"虚拟网络编辑器"

点击"更改设置"

4.在Ubuntu中重启网络服务

1.sudo /etc/init.d/networking restart

ifconfig

2.bind

int bind(int sockfd, const struct sockaddr *addr,

socklen_t addrlen);

功能:

在套接字上绑定一个IP地址和端口号

参数:

sockfd:套接字文件描述符

addr:绑定IP地址空间首地址

addrlen:绑定IP地址的长度

返回值:

成功返回0

失败返回-1

3.UDP编程:

发端:socket -> sendto -> close

收端: socket -> bind -> recvfrom -> close

4.UDP需要注意的细节点:

1.UDP是无连接,发端退出,收端没有任何影响

2.UDP发送数据上限,最好不要超过1500个字节

3.UDP是不安全不可靠的,连续且快速的传输数据容易产生数据丢失

5.wireshark

抓包工具

操作流程:

1.sudo wireshark

打开wireshark抓包工具

2.选择抓取数据包的网卡

any

3.执行通信的代码

4.停止通信

5.设定过滤条件

ip.addr == IP地址

udp

tcp

udp.port == 端口

6.UDP包头长度:8个字节

源端口号(2个字节)

目的端口号(2个字节)

长度(2个字节)

校验和(2个字节)

相关推荐
耶啵奶膘6 分钟前
uniapp-是否删除
linux·前端·uni-app
_.Switch1 小时前
高级Python自动化运维:容器安全与网络策略的深度解析
运维·网络·python·安全·自动化·devops
2401_850410831 小时前
文件系统和日志管理
linux·运维·服务器
qq_254674411 小时前
工作流初始错误 泛微提交流程提示_泛微协同办公平台E-cology8.0版本后台维护手册(11)–系统参数设置
网络
JokerSZ.1 小时前
【基于LSM的ELF文件安全模块设计】参考
运维·网络·安全
XMYX-02 小时前
使用 SSH 蜜罐提升安全性和记录攻击活动
linux·ssh
芯盾时代2 小时前
数字身份发展趋势前瞻:身份韧性与安全
运维·安全·网络安全·密码学·信息与通信
心灵彼岸-诗和远方3 小时前
DevOps业务价值流:架构设计最佳实践
运维·产品经理·devops
一只哒布刘3 小时前
NFS服务器
运维·服务器