Python 基于 TCP 传输协议的网络通信实现
1、基础概念
什么是网络编程?
指在网络环境中,如何实现不在同一物理位置中的计算机之间进行数据通信
如果要保证数据通信顺利完成,则需要先了解如下几个概念:
1.1 协议
不同计算机内的进程之间进行数据通信时,需要先对数据进行封装或打包后方可以进行传输。所谓协议指通信双方需要共同遵守的数据打包格式。
如同现实世界里邮寄商品一样:
- 商品相当于要传送给对方的数据:在传输之前,需要商品拥有者对商品进行打包,并在打包时填写上收件人地址、收什人姓名、发件人地址……这是第一次封装,在此次封装过程中遵守的打包格式是由商品打包者完成,这层打包标准可称为应用层标准或应用层协议。
- 包裹会被物流公司收纳,物流公司每天会收到需要发送至全国各地的包裹,所以,需要再次进行分检,把发送至同一个地区的包裹收纳在一起,并再次进行打包,并按相应的标准进行信息填写。可认为第二次打包的标准是邮局标准或邮局协议.
- 邮局打包后的包裹会发送至相关的运输部门,运输部门会把从不同邮局收集来的包裹按目的地进行归类打包,再选择不同运输工具进行传输,可选择飞机、货车、火车……这次打包协议可称为传输层协议。
协议是保证数据能被正确传输出去的第一操作要素,互联网上所遵守的协议规范称为 TCP/IP 协议。
1.2 IP 地址
在网络环境中,需要为每一台计算机指定一个地址,这个地址叫 IP 地址,其实 IP 地址是一个逻辑地址,而每一台计算机还有一个物理地址,便是网卡上的 MAC 地址。
IP 地址和 MAC 地址的区别?
- MAC 地址相当于你我的身份证号码,是固定、不变的。
- IP 地址相当于你我现在处于的落脚地址.有的人在一年之内,可能会在不同城市工作,也就意味着逻辑地址是可以有多个的。
1.3 端口
一台计算机上可以安装多款网络软件,如 QQ、浏览器、网络游戏……
操作系统如何区分同一时刻自于网络的多个数据应该交给哪一个软件处理?
端口相当于操作系统为每一个网络软件分配的一个门牌标识符号,用来把从网络上输入进来的多数据流正确的分流到对应的进程。
当一台计算机向另一台计算机发送数据时:
- 首先对数据按协议格式进行打包
- 另需要知道对方计算机的地址且还要知道对应进程所监听的端口号.IP+端口号也称为套接字,或叫 socket
有点类似于拜访朋友时:
先封装一个礼物盒
然后根据朋友告诉自己的地址和门牌号前去拜访
2、TCP 网络编程实现
TCP 是一种传输层协议,是可靠的面向连接的传输层协议.
2.1 服务器端编程
定义一个函数用来进行具体的数据交互,由子线程调用.
import socket # socket 模块
import time #时间模块
import threading #线程模块
def session(sock, addr):
print('欢迎新 %s:%s...' % addr)
sock.send(b'Welcome!')
while True:
data = sock.recv(1024)
time.sleep(1)
# 解码数据
if not data or data.decode('utf-8') == 'exit':
break
sock.send(('Hello, %s!' % data.decode('utf-8')).encode('utf-8'))
sock.close()
print('来自于 %s:%s 连接被关闭.' % addr)
创建 socket 监听对象:
#创建 TCP socket
server=socket.socket(socket.AF_INET,socket.SOCK_STREAM)
#监听端口
server.bind(('127.0.0.1',1234))
server.listen(5)
print('服务器正在等待客户的连接……')
建立服务监听套接字,需要指定服务类型:
socket.AF_UNIX |
只能够用于单一的Unix系统进程间通信 |
socket.AF_INET |
服务器之间网络通信 |
socket.AF_INET6 |
IPv6 |
socket.SOCK_STREAM |
流式socket , for TCP |
socket.SOCK_DGRAM |
数据报式socket , for UDP |
socket.SOCK_RAW |
原始套接字,普通的套接字无法处理ICMP、IGMP等网络报文,而SOCK_RAW可以;其次,SOCK_RAW也可以处理特殊的IPv4报文;此外,利用原始套接字,可以通过IP_HDRINCL套接字选项由用户构造IP头。 |
socket.SOCK_SEQPACKET |
可靠的连续数据包服务 |
while True:
# 接受一个新连接:
sock, addr = s.accept()
# 创建新线程来处理TCP连接:
t = threading.Thread(target=session, args=(sock, addr)) t.start()
当有客户连接后,启动线程完成具体的数据处理.
2.2 客户端编程
客户端代码相对而言较简单.
import socket
client = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
# 建立连接:
client.connect(('127.0.0.1', 1234))
# 接收欢迎消息:
print(client.recv(1024).decode('utf-8'))
for data in [b'Rose', b'Think', b'Babala']:
# 发送数据:
s.send(data)
print(s.recv(1024).decode('utf-8'))
s.send(b'exit')
s.close()
测试结果 :
服务器端
客户端:
3 总结
Python 提供了相关的模块,封装了底层的具体代码逻辑,对于开发者而言,只需要按流程按部就班就可以,如果需要更好的理解整个网络通信的过程,则需要了解相关的网络知识.
Python 基于 TCP 传输协议的网络通信实现的更多相关文章
- Qt5 基于TCP传输的发送/接收文件服务器(支持多客户端)
一.实现功能 1.服务器端选择待发送的文件,可以是多个 2.开启服务器,支持多客户端接入,能够实时显示每个客户端接入状态 3.等待所有客户端都处于已连接状态时,依次发送文件集给每个客户端,显示每个客户 ...
- 基于TCP/IP协议的C++网络编程(API函数版)
源代码:http://download.csdn.net/detail/nuptboyzhb/4169959 基于TCP/IP协议的网络编程 定义变量——获得WINSOCK版本——加载WINSOCK库 ...
- TCP传输协议使用
TCP传输协议,也称之为套接字连接,比较安全,三次握手!,必须确保对方计算机存在,才能连接,而且是长时间连接. 缺点是传输速度有点慢. 你用 socket 去连接 ServiceSocaket 服务器 ...
- Unity C# 自定义TCP传输协议以及封包拆包、解决粘包问题
本文只是初步实现了一个简单的TCP自定协议,更为复杂的协议可以根据这种方式去扩展. TCP协议,通俗一点的讲,它是一种基于socket传输的由发送方和接收方事先协商好的一种消息包组成结构,主要由消息头 ...
- 基于tcp/udp协议的套接字通信
目录 一.套接字分类 二.套接字的工作流程 三.基于tcp协议的套接字 四.基于udp协议的套接字 一.套接字分类 1.基于文件类型的套接字家族:AF_UNIX 2.基于网络类型的套接字家族:AF_I ...
- 基于UDP传输协议局域网文件接收软件设计 Java版
网路传输主要的两大协议为TCP/IP协议和UDP协议,本文主要介绍基于UDP传输的一个小软件分享,针对于Java网络初学者是一个很好的练笔,大家可以参考进行相关的联系,但愿能够帮助到大家. 话不多说, ...
- 读书笔记——网络编程与开发技术(3)基于TCP/IP协议的网络编程相关知识
TCP/IP协议:数据链路层,网络层,传输层,应用层. IP地址分为5类:A类.B类.C类.D类.E类. (A类.B类.C类是基本类,D类多用于多播传送,E类为保留类.) "*"表 ...
- TCP传输协议中如何解决丢包问题
TCP在不可靠的网络上实现可靠的传输,必然会有丢包.TCP是一个“流”协议,一个详细的包将会被TCP拆分为好几个包上传,也是将会把小的封裝成大的上传,这就是说TCP粘包和拆包难题. 但是许多人有不同的 ...
- 基于TCP/UDP协议的socket
基于TCP协议的socket tcp是基于链接的,必须先启动服务端,然后再启动客户端去链接服务端 server端 import socket sk = socket.socket() sk.bind( ...
随机推荐
- 基于Spring实现策略模式
背景: 看多很多策略模式,总结下来实现原理大体都差不多,在这里主要是讲解下自己基于Spring更优雅的实现方案:这个方案主要是看了一些开源rpc和Spring相关源码后的一些思路,所以在此进行总结 首 ...
- 【分布式技术专题】「Zookeeper中间件」给大家学习一下Zookeeper的”开发伴侣”—Curator-Framework(基础篇)
CuratorFramework基本介绍 CuratorFramework是Netflix公司开源的一套Zookeeper客户端框架,它作为一款优秀的ZooKeeper客户端开源工具,主要提供了对客户 ...
- [.Net]使用ABP 数据库迁移migration遇到的坑及解决方案
问题:在使用Update-Database时,突然出现"数据库中已存在名为 'XXX' 的对象". 检查发现__EFMigrationsHistory表中的MigrationI ...
- C#winform控件序列化,反序列化
using System; using System.Collections.Generic; using System.Drawing; using System.IO; using System. ...
- Xamarin/Unity3d无法访问Azure服务器或者微软API
Xamarin因为是mono项目的商用版,mono项目是.net技术的开源修改版,所以和微软的服务对接时候会出现安全验证问题. mono项目本质是对汇编级的中间语言二次编译.可参考公共语言运行时相关知 ...
- CMake语法—内置变量
目录 CMake语法-内置变量 1 CMake变量分类 1.1 普通变量 1.2 缓存变量 1.3 环境变量 1.4 内置变量 2 CMake内置变量分类 2.1 提供信息的变量 2.2 改变行为的变 ...
- POSIX之共享内存
shm_write.c: #include<stdio.h> #include<stdlib.h> #include <stdlib.h> #include < ...
- 如何使用c#编写单片机程序
因为个人喜爱想研究单片机,但是不太会c,然后再找资料研究有没有其他的方法发现国外的c# nanoframework 框架可以编写单片机程序,本文我将会用自己踩过的坑来总结一些c#编写单片机的一些经 ...
- .NET6: 开发基于WPF的摩登三维工业软件
MS Office和VisualStudio一直引领着桌面应用的时尚潮流,大型的工业软件一般都会紧跟潮流,搭配着Ribbon和DockPanel风格的界面.本文将介绍WPF下两个轻量级的Ribbon和 ...
- 资本主义反抗指南精要(v0.1)
(1)充分预估工作时间,比如一小时的开发任务,你可以加上技术调研,API/数据库设计,单元测试,联调,集成测试等等,拖到一天,同理一天的任务可以拖到一星期. (2)简历上尽一切手段来美化,最好能包装成 ...