python中的TCP编程学习
今天看了一下关于python的TCP编程。
发现思路和其他语言(比如java)思路基本上差点儿相同。
先看client。基本过程例如以下:
- 第一步:创建一个socket
- 第二步:建立连接
- 第三步:发送数据
- 第四步:读取从server发送过来的数据
- 第五步:关闭连接
- 第六步:对收到的数据进行处理
以下为python的TCP编程的client程序的一个小样例。java中关于网络编程的博文请看这里
#coding:utf-8
#TCP编程的client程序
#编写client程序与其他语言(比如java)的思路差点儿相同。例如以下
#第一步:创建一个socket
import socket
s=socket.socket(socket.AF_INET,socket.SOCK_STREAM)
#第二步:建立连接,參数是一个tuple,以訪问新浪为例
s.connect(('www.sina.com.cn',80))#80port是Web服务的标准port
#第三步:发送数据
s.send(b'GET / HTTP/1.1\r\n Host:www.sina.com.cn\r\nConnection:close\n\r\n')
#第四步:接收数据
buffer=[]
while True:
d=s.recv(1024) #recv(max)方法。表示每次仅仅能读取max个字节
if d:
buffer.append(d)
else:
break
date=b''.join(buffer)
#第五步:关闭连接
s.close()
#第六步:对接收到的数据进行处理
#因为接收到的数据包含http头和网页本身。因此将其分开
header,html=date.split(b'\r\n\r\n',1)
print(header.decode('utf-8'))
with open('sina.html','wb') as f:
f.write(html)
以下看server端的程序。思路例如以下
- 第一步:创建一个socket
- 第二步:绑定监听的地址和port,方法bind()仅仅接收一个tuple
- 第三步:调用listen()方法開始监听port,传入的參数指定等待连接的最大数量
- 第四步:server程序通过一个永久循环来接收来自client。accept()会等待并返回一个client的连接
#python中的server端的程序,其用来測试的client程序为:tcpClient1.py
#coding:utf-8
import socket
import threading
def tcplink(sock,addr):
print('Accept new connection from %s:%s...'%addr)
sock.send(b'welcome')
while True:
date=sock.recv(1024)
if not date or date.decode('utf-8')=='exit':
break
print(date.decode('utf-8'))
sock.close()
print('Connection from %s:%s'%addr)
#第一步:创建一个socket
s=socket.socket(socket.AF_INET,socket.SOCK_STREAM)
#第二步:绑定监听的地址和port,方法bind()仅仅接收一个tuple
s.bind(('127.0.0.1',9999))
#第三步:调用listen()方法開始监听port。传入的參数指定等待连接的最大数量
s.listen(10)
#第四步:server程序通过一个永久循环来接收来自client,accept()会等待并返回一个client的连接
while True:
sock,addr=s.accept()
#创建一个新线程来处理TCP链接
threading.Thread(target=tcplink,args=(sock,addr)).start()
測试上面的server端的程序。我们用一个简单的client程序来測试。例如以下
#为tcpServerserver端写一个測试的client程序
#coding:utf-8
import socket
#第一步:创建一个socket
s=socket.socket(socket.AF_INET,socket.SOCK_STREAM)
#第二步:建立连接
s.connect(('127.0.0.1',9999))
#第三步:发送数据
s.send(b'hello World!')
#第三步:接收数据
date=s.recv(1024)
print(date.decode('utf-8'))
刚好前几天系统的学习了一下git版本号控制这个工具。于是,也就開始经营我的Github了,上面的代码可在我的Github中下载,点击这里就可以
參考地址例如以下:关于TCP编程的具体介绍http://www.liaoxuefeng.com/wiki/0014316089557264a6b348958f449949df42a6d3a2e542c000/001432004374523e495f640612f4b08975398796939ec3c000
python中的TCP编程学习的更多相关文章
- Python中的TCP编程,实现客户端与服务器的聊天(socket)
参考大神blog:自己再写一个 https://blog.csdn.net/qq_31187881/article/details/79067644
- python中的tcp示例详解
python中的tcp示例详解 目录 TCP简介 TCP介绍 TCP特点 TCP与UDP的不同点 udp通信模型 tcp客户端 tcp服务器 tcp注意点 TCP简介 TCP介绍 TCP协议 ...
- Python中的并发编程
简介 我们将一个正在运行的程序称为进程.每个进程都有它自己的系统状态,包含内存状态.打开文件列表.追踪指令执行情况的程序指针以及一个保存局部变量的调用栈.通常情况下,一个进程依照一个单序列控制流顺序执 ...
- Python 中的 TK编程
可爱的 Python:Python 中的 TK编程 http://www.ibm.com/developerworks/cn/linux/sdk/python/charm-12/ python che ...
- 可爱的 Python : Python中的函数式编程,第三部分
英文原文:Charming Python: Functional programming in Python, Part 3,翻译:开源中国 摘要: 作者David Mertz在其文章<可爱的 ...
- Python中的多线程编程,线程安全与锁(二)
在我的上篇博文Python中的多线程编程,线程安全与锁(一)中,我们熟悉了多线程编程与线程安全相关重要概念, Threading.Lock实现互斥锁的简单示例,两种死锁(迭代死锁和互相等待死锁)情况及 ...
- Python中的Tcp协议的应用之Tcp服务端程序开发
TCP通信协议是面向连接的可靠的网络通信协议. 网络间想要进行数据传输必须要用到socket,socket翻译过来叫做套接字,其主要作用是不同设备或同一台设备之间的进程通信工具. Python中的Tc ...
- Python中的并行编程速度
这里主要想记录下今天碰到的一个小知识点:Python中的并行编程速率如何? 我想把AutoTool做一个并行化改造,主要目的当然是想提高多任务的执行速度.第一反应就是想到用多线程执行不同模块任务,但是 ...
- python进阶---Python中的socket编程
初识socket编程 一.前言 socket基于C\S架构(客户端\服务端)的编程模型,在Python中是以socket模块存在的. Socket是应用层与TCP/IP协议族通信的中间软件抽象层,它是 ...
随机推荐
- CentOS 忘记root密码,解决方法
1.开机后,在倒数5秒结束前,按下任意键 2.在显示centos...的那个界面下,按e键(edit) 3.会出现三行的界面,选择中间 kernel...那行,然后按e键 4.在接着出现的那个界面最后 ...
- 18 4Sum(寻找四个数之和为指定数的集合Medium)
题目意思:给一个乱序数组,在里面寻找三个数之和为target的所有情况,这些情况不能重复,增序排列 思路:采用3Sum的做法 ps:有见一种用hash的,存任意两个元素的和,然后变成3sum问题,需要 ...
- 用jQuery实现瀑布流效果学习笔记
jQuery一直没系统的学,只知道是js库,封装了好多js函数,方便了开发.以前做过一个原生的图片网站瀑布流效果,超级麻烦,这次用了jQuery方法,瞬间代码浓缩了,只有56行js代码.神奇的让我来把 ...
- PHP要注意的14个问题
1.页面之间无法传递变量 get,post,session 在最新的php版本中自动全局变量是关闭的,所以要从上一页面取得提交过来得变量要使 用$_GET['foo'],$_POST['foo'],$ ...
- beego路由实现原理
树形结构+递归算法实现路由的注册与匹配: 1 数据结构: // 树节点结构type Tree struct { //search fix route first fixrouters map[stri ...
- C++类:private、public、friend、protected的区别
private和public的作用是让编译器帮你检查某些模块是否使用了他没权限使用的模块,也就是生成可执行代码的时候做权限检查.比如,公司里各个部门有自己私有的信息,财务部可以看所有员工 ...
- 这十大MCU厂商瓜分着中国市场
MCU(Micro Control Unit)中文名称为微控制单元,又称单片微型计算机(Single Chip Microcomputer)或者单片机,是指随着大规模集成电路的出现及其发展,将计算机的 ...
- zabbix 添加jvm监控
1. zabbix 服务端安装,监控jmx 需要--enable-java zabbix 客户端不需要 --enable-java 2.zabbix_server端安装jdk 安装jdk [root@ ...
- 【HDOJ】1760 A New Tetris Game
博弈,主要是求SG值.终于做出点儿感觉. /* 1760 */ #include <cstdio> #include <cstring> #include <cstdli ...
- 嵌入式ARM-Linux开发工具下载地址合集
insight gdb http://ftp.twaren.net/Unix/Sourceware/ 说明:GDB可视化调试工具 http://gro.clinux.org/frs/?group_i ...