逆向学习网络篇:心跳包与TCP服务器

简介: 逆向学习网络篇:心跳包与TCP服务器

在网络通信中,心跳包是一种重要的机制,用于维持客户端与服务器之间的连接状态。本文将深入探讨心跳包的概念、实现过程、命名原因,以及TCP服务器的创建和连接过程,并通过代码案例来展示这些概念的实际应用。

1. 心跳包机制

心跳包是客户端每隔一段时间向服务器发送的数据包,用于告知服务器客户端仍然在线。服务器会定时检查客户端发包时间,以检测客户端是否在线。如果服务器在一定时间内没有收到心跳包,则可以认为客户端已经离线。

import socket
import time
# 客户端代码
def send_heartbeat(client_socket, interval=5):
    while True:
        client_socket.send(b'Heartbeat')
        time.sleep(interval)
# 创建socket
client_socket = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
client_socket.connect(('localhost', 8000))
# 发送心跳包
send_heartbeat(client_socket)

2. TCP连接与心跳包的建立与作用

TCP是一种可靠的、面向连接的协议,它保证了数据传输的顺序和完整性。在TCP服务器中,连接的建立需要经过三次握手的过程。心跳包的作用在于确保连接的活跃状态,防止因长时间无数据传输而被网络设备断开连接。

3. TCP服务器socket编程

创建一个TCP服务器通常包括以下步骤:创建socket、绑定端口、监听连接、接受连接、处理数据、关闭连接。

import socket
# 服务器代码
def handle_client(client_socket):
    while True:
        data = client_socket.recv(1024)
        if not data:
            break
        client_socket.send(data)
    client_socket.close()
# 创建socket
server_socket = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
server_socket.bind(('localhost', 8000))
server_socket.listen(5)
while True:
    client_socket, addr = server_socket.accept()
    print('Connection from:', addr)
    handle_client(client_socket)

4. Socket编程基础

服务器端代码

import socket
# 创建一个TCP socket
server_socket = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
# 绑定IP地址和端口
server_socket.bind(('localhost', 12345))
# 开始监听,最大连接数为5
server_socket.listen(5)
print("Server is listening on port 12345...")
while True:
    # 接受客户端连接
    client_socket, client_address = server_socket.accept()
    print(f"Accepted connection from {client_address}")
    # 接收数据
    data = client_socket.recv(1024)
    print(f"Received: {data.decode()}")
    # 发送数据
    response = "Hello, client!".encode()
    client_socket.send(response)
    # 关闭客户端socket
    client_socket.close()

客户端代码

import socket
# 创建一个TCP socket
client_socket = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
# 连接服务器
client_socket.connect(('localhost', 12345))
# 发送数据
message = "Hello, server!".encode()
client_socket.send(message)
# 接收数据
data = client_socket.recv(1024)
print(f"Received: {data.decode()}")
# 关闭socket
client_socket.close()

在这个案例中,服务器创建了一个TCP socket,绑定到本地地址和端口12345,并开始监听连接。客户端创建了一个TCP socket,并尝试连接到服务器。一旦连接建立,客户端发送一条消息给服务器,服务器接收并打印这条消息,然后发送一条响应消息给客户端。客户端接收并打印服务器的响应,最后关闭socket。这个简单的交互展示了Socket编程的基础操作,包括socket的创建、连接、数据的发送和接收。

5. TCP数据包处理和监听

import socket
# 服务器代码
def handle_data(client_socket):
    # 假设数据包格式为:包头(4字节) + 数据(10字节) + 附加数据(6字节)
    header = client_socket.recv(4)
    data = client_socket.recv(10)
    additional_data = client_socket.recv(6)
    # 处理接收到的数据
    print("Received header:", header)
    print("Received data:", data)
    print("Received additional data:", additional_data)
# 创建socket
server_socket = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
server_socket.bind(('localhost', 8000))
server_socket.listen(5)
print("Server listening on port 8000...")
while True:
    client_socket, addr = server_socket.accept()
    print('Connection from:', addr)
    handle_data(client_socket)

6. TCP数据包的接收与处理

import socket
# 服务器代码
def handle_packet(client_socket):
    while True:
        # 先接收包头
        header = client_socket.recv(4)
        if not header:
            break
        # 根据包头信息接收数据
        data = b''
        while len(data) < header[0]:  # 假设包头第一个字节指示数据长度
            packet = client_socket.recv(header[0] - len(data))
            if not packet:
                break
            data += packet
        # 处理接收到的数据
        if data:
            print("Received data:", data)
        else:
            print("Received header only, no data.")
# 创建socket
server_socket = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
server_socket.bind(('localhost', 8000))
server_socket.listen(5)
while True:
    client_socket, addr = server_socket.accept()
    print('Connection from:', addr)
    handle_packet(client_socket)

7. 服务器和客户端的通讯问题

import socket
# 客户端代码
def send_data(client_socket, data):
    # 确保使用正确的socket发送数据
    if client_socket and client_socket.connected:
        client_socket.send(data)
    else:
        print("Error: Socket not connected.")
# 创建socket
client_socket = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
client_socket.connect(('localhost', 8000))
# 发送数据
data_to_send = b'Hello, server!'
send_data(client_socket, data_to_send)

以上代码案例展示了如何处理TCP数据包、监听端口、接收和处理数据包,以及如何确保服务器和客户端之间的通讯正确无误。这些案例可以帮助理解TCP服务器和客户端在实际应用中的工作流程。

目录
相关文章
|
4月前
|
机器学习/深度学习 算法 数据挖掘
没发论文的注意啦!重磅更新!GWO-BP-AdaBoost预测!灰狼优化、人工神经网络与AdaBoost集成学习算法预测研究(Matlab代码实现)
没发论文的注意啦!重磅更新!GWO-BP-AdaBoost预测!灰狼优化、人工神经网络与AdaBoost集成学习算法预测研究(Matlab代码实现)
171 0
|
4月前
|
存储 弹性计算 网络协议
阿里云服务器ECS实例规格族是什么?不同规格CPU型号、处理器主频及网络性能参数均不同
阿里云ECS实例规格族是指具有不同性能特点和适用场景的实例类型集合。不同规格族如计算型c9i、通用算力型u1、经济型e等,在CPU型号、主频、网络性能、云盘IOPS等方面存在差异。即使CPU和内存配置相同,性能参数和价格也各不相同,适用于不同业务需求。
423 144
|
5月前
|
JSON 监控 API
在线网络PING接口检测服务器连通状态免费API教程
接口盒子提供免费PING检测API,可测试域名或IP的连通性与响应速度,支持指定地域节点,适用于服务器运维和网络监控。
544 0
|
5月前
|
机器学习/深度学习 存储 监控
内部文件审计:企业文件服务器审计对网络安全提升有哪些帮助?
企业文件服务器审计是保障信息安全、确保合规的关键措施。DataSecurity Plus 是由卓豪ManageEngine推出的审计工具,提供全面的文件访问监控、实时异常告警、用户行为分析及合规报告生成功能,助力企业防范数据泄露风险,满足GDPR、等保等多项合规要求,为企业的稳健发展保驾护航。
156 0
|
3月前
|
JavaScript Java 大数据
基于python的网络课程在线学习交流系统
本研究聚焦网络课程在线学习交流系统,从社会、技术、教育三方面探讨其发展背景与意义。系统借助Java、Spring Boot、MySQL、Vue等技术实现,融合云计算、大数据与人工智能,推动教育公平与教学模式创新,具有重要理论价值与实践意义。
|
4月前
|
存储 监控 Linux
Dell OpenManage Enterprise 4.5 - Dell 服务器、存储和网络设备集中管理软件
Dell OpenManage Enterprise 4.5 - Dell 服务器、存储和网络设备集中管理软件
119 0
|
5月前
|
弹性计算 运维 Kubernetes
看阿里云操作系统控制台如何一招擒拿网络丢包
阿里云操作系统控制台帮忙客户快速定位问题,不仅成功完成业务部署并实现稳定运行,更有效遏制了持续性成本消耗。
|
2月前
|
弹性计算 运维 安全
阿里云轻量应用服务器与云服务器ECS啥区别?新手帮助教程
阿里云轻量应用服务器适合个人开发者搭建博客、测试环境等低流量场景,操作简单、成本低;ECS适用于企业级高负载业务,功能强大、灵活可扩展。二者在性能、网络、镜像及运维管理上差异显著,用户应根据实际需求选择。
273 10
|
2月前
|
运维 安全 Ubuntu
阿里云渠道商:服务器操作系统怎么选?
阿里云提供丰富操作系统镜像,涵盖Windows与主流Linux发行版。选型需综合技术兼容性、运维成本、安全稳定等因素。推荐Alibaba Cloud Linux、Ubuntu等用于Web与容器场景,Windows Server支撑.NET应用。建议优先选用LTS版本并进行测试验证,通过标准化镜像管理提升部署效率与一致性。
|
2月前
|
弹性计算 ice
阿里云4核8g服务器多少钱一年?1个月和1小时价格,省钱购买方法分享
阿里云4核8G服务器价格因实例类型而异,经济型e实例约159元/月,计算型c9i约371元/月,按小时计费最低0.45元。实际购买享折扣,1年最高可省至1578元,附主流ECS实例及CPU型号参考。
416 8

热门文章

最新文章