python中的网络编程

一、IP 地址的介绍

1.IP 地址的概念

python中的网络编程_端口号

2.IP 地址的表现形式

python中的网络编程_客户端_02
python中的网络编程_服务端_03

3.IP 地址的作用

python中的网络编程_服务端_04

4.查看 IP 地址

python中的网络编程_端口号_05
python中的网络编程_端口号_06

5.检查网络是否正常

python中的网络编程_网络_07

6.小结

python中的网络编程_端口号_08

二、端口和端口号的介绍

1.问题思考

python中的网络编程_网络_09

2.什么是端口

python中的网络编程_网络_10

3.什么端口号

python中的网络编程_网络_11

4.端口和端口号的关系

端口号可以标识唯一的一个端口。

5.端口号的分类

python中的网络编程_服务端_12

6.小结

python中的网络编程_端口号_13

三、TCP 的介绍

1.网络应用程序之间的通信流程

python中的网络编程_端口号_14

2.TCP 的概念

python中的网络编程_网络_15
python中的网络编程_服务端_16

3.TCP 的特点

python中的网络编程_端口号_17

4.总结

TCP 是一个稳定、可靠的传输协议,常用于对数据进行准确无误的传输,比如: 文件下载,浏览器上网。

四、socket 的介绍

1.问题思考

python中的网络编程_端口号_18

2.socket 的概念

python中的网络编程_服务端_19
python中的网络编程_端口号_20

3.socket 的作用

负责进程之间的网络数据传输,好比数据的搬运工。

4.socket 使用场景

python中的网络编程_python_21

5.小结

进程之间网络数据的传输可以通过 socket 来完成, socket 就是进程间网络数据通信的工具。

五、TCP 网络应用程序开发流程

1.TCP 网络应用程序开发流程的介绍

python中的网络编程_客户端_22

2.TCP 客户端程序开发流程的介绍

python中的网络编程_python_23
python中的网络编程_python_24

3. TCP 服务端程序开发流程的介绍

python中的网络编程_python_25
python中的网络编程_网络_26

4.小结

python中的网络编程_网络_27

六、TCP 客户端程序开发

1.开发 TCP 客户端程序开发步骤回顾

python中的网络编程_端口号_28

2.socket 类的介绍

python中的网络编程_端口号_29

3.TCP 客户端程序开发示例代码

import socket


if __name__ == '__main__':
    # 创建tcp客户端套接字
    # 1. AF_INET:表示ipv4
    # 2. SOCK_STREAM: tcp传输协议
    tcp_client_socket = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
    # 和服务端应用程序建立连接
    tcp_client_socket.connect(("192.168.131.62", 8080))
    # 代码执行到此,说明连接建立成功
    # 准备发送的数据
    send_data = "你好服务端,我是客户端小黑!".encode("gbk")
    # 发送数据
    tcp_client_socket.send(send_data)
    # 接收数据, 这次接收的数据最大字节数是1024
    recv_data = tcp_client_socket.recv(1024)
    # 返回的直接是服务端程序发送的二进制数据
    print(recv_data)
    # 对数据进行解码
    recv_content = recv_data.decode("gbk")
    print("接收服务端的数据为:", recv_content)
    # 关闭套接字
    tcp_client_socket.close()

python中的网络编程_服务端_30
网络调试助手充当服务端程序:
python中的网络编程_python_31

4.小结

python中的网络编程_python_32

七、TCP服务端程序开发

1.开发 TCP 服务端程序开发步骤回顾

python中的网络编程_服务端_33

2.socket 类的介绍

python中的网络编程_服务端_34

3.TCP 服务端程序开发示例代码

import socket

if __name__ == '__main__':
    # 创建tcp服务端套接字
    tcp_server_socket = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
    # 设置端口号复用,让程序退出端口号立即释放
    tcp_server_socket.setsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR, True) 
    # 给程序绑定端口号
    tcp_server_socket.bind(("", 8989))
    # 设置监听
    # 128:最大等待建立连接的个数, 提示: 目前是单任务的服务端,同一时刻只能服务与一个客户端,后续使用多任务能够让服务端同时服务与多个客户端,
    # 不需要让客户端进行等待建立连接
    # listen后的这个套接字只负责接收客户端连接请求,不能收发消息,收发消息使用返回的这个新套接字来完成
    tcp_server_socket.listen(128)
    # 等待客户端建立连接的请求, 只有客户端和服务端建立连接成功代码才会解阻塞,代码才能继续往下执行
    # 1. 专门和客户端通信的套接字: service_client_socket
    # 2. 客户端的ip地址和端口号: ip_port
    service_client_socket, ip_port = tcp_server_socket.accept()
    # 代码执行到此说明连接建立成功
    print("客户端的ip地址和端口号:", ip_port)
    # 接收客户端发送的数据, 这次接收数据的最大字节数是1024
    recv_data = service_client_socket.recv(1024)
    # 获取数据的长度
    recv_data_length = len(recv_data)
    print("接收数据的长度为:", recv_data_length)
    # 对二进制数据进行解码
    recv_content = recv_data.decode("gbk")
    print("接收客户端的数据为:", recv_content)
    # 准备发送的数据
    send_data = "ok, 问题正在处理中...".encode("gbk")
    # 发送数据给客户端
    service_client_socket.send(send_data)
    # 关闭服务与客户端的套接字, 终止和客户端通信的服务
    service_client_socket.close()
    # 关闭服务端的套接字, 终止和客户端提供建立连接请求的服务
    tcp_server_socket.close()

python中的网络编程_服务端_35
python中的网络编程_服务端_36

4.小结

python中的网络编程_python_37

八、TCP网络应用程序的注意点

python中的网络编程_python_38

九、案例-多任务版TCP服务端程序开发

1.需求

python中的网络编程_端口号_39

2.具体实现步骤

python中的网络编程_客户端_40

3.多任务版TCP服务端程序的示例代码:

import socket
import threading


# 处理客户端的请求操作
def handle_client_request(service_client_socket, ip_port):
    # 循环接收客户端发送的数据
    while True:
        # 接收客户端发送的数据
        recv_data = service_client_socket.recv(1024)
        # 容器类型判断是否有数据可以直接使用if语句进行判断,如果容器类型里面有数据表示条件成立,否则条件失败
        # 容器类型: 列表、字典、元组、字符串、set、range、二进制数据
        if recv_data:
            print(recv_data.decode("gbk"), ip_port)
            # 回复
            service_client_socket.send("ok,问题正在处理中...".encode("gbk"))

        else:
            print("客户端下线了:", ip_port)
            break
    # 终止和客户端进行通信
    service_client_socket.close()


if __name__ == '__main__':
    # 创建tcp服务端套接字
    tcp_server_socket = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
    # 设置端口号复用,让程序退出端口号立即释放
    tcp_server_socket.setsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR, True)
    # 绑定端口号
    tcp_server_socket.bind(("", 9090))
    # 设置监听, listen后的套接字是被动套接字,只负责接收客户端的连接请求
    tcp_server_socket.listen(128)
    # 循环等待接收客户端的连接请求
    while True:
        # 等待接收客户端的连接请求
        service_client_socket, ip_port = tcp_server_socket.accept()
        print("客户端连接成功:", ip_port)
        # 当客户端和服务端建立连接成功以后,需要创建一个子线程,不同子线程负责接收不同客户端的消息
        sub_thread = threading.Thread(target=handle_client_request, args=(service_client_socket, ip_port))
        # 设置守护主线程
        sub_thread.setDaemon(True)
        # 启动子线程
        sub_thread.start()


    # tcp服务端套接字可以不需要关闭,因为服务端程序需要一直运行
    # tcp_server_socket.close()

python中的网络编程_网络_41

4.小结

编写一个TCP服务端程序,循环等待接受客户端的连接请求

 while True:
     service_client_socket, ip_port = tcp_server_socket.accept()

当客户端和服务端建立连接成功,创建子线程,使用子线程专门处理客户端的请求,防止主线程阻塞

 while True:
     service_client_socket, ip_port = tcp_server_socket.accept() 
     sub_thread = threading.Thread(target=handle_client_request, args=(service_client_socket, ip_port))
     sub_thread.start()

把创建的子线程设置成为守护主线程,防止主线程无法退出。

 while True:
     service_client_socket, ip_port = tcp_server_socket.accept() 
     sub_thread = threading.Thread(target=handle_client_request, args=(service_client_socket, ip_port))
     sub_thread.setDaemon(True) 
     sub_thread.start()

十、socket之send和recv原理剖析

1.认识TCP socket的发送和接收缓冲区

当创建一个TCP socket对象的时候会有一个发送缓冲区和一个接收缓冲区,这个发送和接收缓冲区指的就是内存中的一片空间。

2.send原理剖析

python中的网络编程_服务端_42

3. recv原理剖析

python中的网络编程_网络_43

4.send和recv原理剖析图

python中的网络编程_客户端_44

5.小结

不管是recv还是send都不是直接接收到对方的数据和发送数据到对方,发送数据会写入到发送缓冲区,接收数据是从接收缓冲区来读取,发送数据和接收数据最终是由操作系统控制网卡来完成。