TCP语法

1 建立一个socket对象

import socket
sk = socket.socket()
print (sk)

执行

[root@node10 python]# python3 test.py
<socket.socket fd=3, family=AddressFamily.AF_INET, type=SocketKind.SOCK_STREAM, proto=0, laddr=('0.0.0.0', 0)>

2 使用socket建立连接发送消息

服务端发消息,客户端接收消息

服务端过程

  1. 创建一个socket对象 # 默认返回tcp协议的对象
  2. 绑定ip和端口 (把该主机注册到网络里,让别人找到你)
  3. 开启监听
  4. 三次握手 conn 是建立三次握手之后返回的对象, addr 是对方的ip地址
  5. 写收发消息的逻辑,服务端发送消息 发送消息的数据类型一定的是二进制字节流
  6. 四次挥手
  7. 退还端口,先启动服务端,在启动客户端,一发一收是一对,不能多发也不能多收

[root@node10 tcp]# cat /python/tcp/server.py

import socket
# 1.创建一个socket对象 # 默认返回tcp协议的对象
sk = socket.socket()
# 2.绑定ip和端口 (把该主机注册到网络里,让别人找到你)
# 127.0.0.1 默认指代本机的ip地址
sk.bind( ("127.0.0.1",9000) )
# 3.开启监听
sk.listen() # 4.三次握手 conn 是建立三次握手之后返回的对象, addr 是对方的ip地址
# accept() 必须建立好握手之后,下面的代码才能执行,因为其中加了阻塞.
# 比如input sleep.. 都是程序内部加了阻塞.
conn,addr = sk.accept() # 5.写收发消息的逻辑
# ...
# 服务端接收消息 同一时间最多最多接收1024个字节
msg = conn.recv(1024) # 程序内部加了阻塞,不接受数据,不会向下执行
print(msg.decode("utf-8")) # 服务端发送消息 发送消息的数据类型一定的是二进制字节流
conn.send("nice to meet you too".encode("utf-8")) # 不发送完毕之后,不会关闭连接 # 6.四次挥手
conn.close() # 7.退还端口
sk.close() # 先启动服务端,在启动客户端,一发一收是一对,不能多发也不能多收

执行

[root@node10 tcp]# python3 server.py

这里会被阻塞,查看端口,发现9000端口已经被占用

创建一个客户端文件

 ### 客户端

import socket
# 产生一个socket对象
sk = socket.socket()
# 建立连接
sk.connect( ("127.0.0.1",9000) ) # send 发送消息 参数必须是二进制的字节流
sk.send("nice to meet you !".encode("utf-8")) # recv 接收消息
res = sk.recv(1024)
print(res.decode("utf-8"))
# 关闭连接
sk.close()

执行

然后查看服务端

客户端

打印看一下conn,addr的值

import socket
sk = socket.socket()
sk.bind( ("127.0.0.1",9000) )
sk.listen()
conn,addr = sk.accept()
print (conn,addr)
msg = conn.recv(1024)
print(msg.decode("utf-8"))
conn.send("nice to meet you too".encode("utf-8"))
conn.close()
sk.close()

执行然后执行client端,得到

<socket.socket fd=4, 
family=AddressFamily.AF_INET,
type=SocketKind.SOCK_STREAM,
proto=0,
laddr=('127.0.0.1', 9000),
raddr=('127.0.0.1', 44368)> ('127.0.0.1', 44368)

3 使用socket循环发消息

import socket

sk = socket.socket()
#注册主机
sk.bind ( ("127.0.0.1",9000) ) #参数式元组
#开启监听
sk.listen()
#三次握手
conn,addr = sk.accept() msg = conn.recv(1024)
print (msg.decode("utf-8")) #四次挥手
conn.close()
#退还端口
sk.close()

客户端

import socket
sk = socket.socket()
sk.connect( ("127.0.0.1",9000) )
message = input(">>>:")
sk.send(message.encode("utf-8"))
sk.close()

先执行服务端  在执行客户端,并在客户端输值

[root@node10 tcp]# python3 server.py

[root@node10 tcp]# python3 client.py
>>>:hi
[root@node10 tcp]# python3 server.py
hi

循环执行客户端发消息

#服务端
import socket sk = socket.socket()
#注册主机
sk.bind ( ("127.0.0.1",9000) ) #参数式元组
#开启监听
sk.listen()
#三次握手
#conn,addr = sk.accept()
while True:
conn,addr = sk.accept()
while True:
msg = conn.recv(1024)
print (msg.decode("utf-8")) #四次挥手
conn.close()
#退还端口
sk.close()

客户端

import socket
sk = socket.socket()
sk.connect( ("127.0.0.1",9000) )
while True:
message = input(">>>:")
sk.send(message.encode("utf-8"))
sk.close()

效果

[root@node10 tcp]# python3 server.py
[root@node10 tcp]# python3 client.py
>>>:123
>>>:456
>>>:nihao
>>>:hello
>>>:
[root@node10 tcp]# python3 server.py
123
456
nihao
hello

4 服务端和客户端户发消息

服务端

import socket

sk = socket.socket()
#注册主机
sk.bind ( ("127.0.0.1",9000) ) #参数式元组
#开启监听
sk.listen()
#三次握手
#conn,addr = sk.accept()
while True:
conn,addr = sk.accept()
while True:
msg = conn.recv(1024)
print (msg.decode("utf-8"))
#服务端发消息
message = input("我要发数据>>>:")
conn.send(message.encode("utf-8"))
#四次挥手
conn.close()
#退还端口
sk.close()

客户端

import socket
sk = socket.socket()
sk.connect( ("127.0.0.1",9000) )
while True:
message = input(">>>:")
sk.send(message.encode("utf-8"))
#接收服务端消息
res = sk.recv(1024)
print (res.decode("utf-8"))
sk.close()

执行

[root@node10 tcp]# python3 server.py
hi #这里阻塞,等待客户端发消息,接收到客户端消息,可以给客户端发送消息
我要发数据>>>:hi #向客户端发送消息
nice to meet you
我要发数据>>>:nice to meet you too!
[root@node10 tcp]# python3 client.py
>>>:hi #向服务端发送消息,然后阻塞,等待服务端的消息
hi #接收到服务端的消息,可以继续向服务端发送消息
>>>:nice to meet you
nice to meet you too!

但是这种情况下,当再有一个客户端连接,是无法连接的,在开启一个窗口

执行client.py

[root@node10 tcp]# python3 client.py
>>>:123 #向服务端发送数据
[root@node10 tcp]# python3 server.py
hi
我要发数据>>>:hi
nice to meet you
我要发数据>>>:nice to meet you too! #但是服务端没有任何反应,需要断开连接

5 断开连接

断开客户端连接,同时服务端不会断开,可以等待下一个客户端的连接

import socket

sk = socket.socket()
#注册主机
sk.bind ( ("127.0.0.1",9000) ) #参数式元组
#开启监听
sk.listen()
#三次握手
#conn,addr = sk.accept()
while True:
conn,addr = sk.accept()
while True:
msg = conn.recv(1024)
print (msg.decode("utf-8"))
#服务端发消息
message = input("我要发数据>>>:")
conn.send(message.encode("utf-8"))
if message == "q": #当发送的消息式q是,退出这个循环,即和客户端结束连接,但是上一层循环,并没有结束,可以等待下一个的客户端进来
break
#四次挥手
conn.close()
#退还端口
sk.close()

客户端

import socket
sk = socket.socket()
sk.connect( ("127.0.0.1",9000) )
while True:
message = input(">>>:")
sk.send(message.encode("utf-8"))
#接收服务端消息
res = sk.recv(1024)
if res == b"q": #当接收到服务端的q信息,就退出循环,即断开连接,b"q"表示接收的二进制流是q
break
print (res.decode("utf-8"))
sk.close()

执行

[root@node10 tcp]# python3 server.py
Hi
我要发数据>>>:Hi
Nice to meet you!
我要发数据>>>:Nice to meet you too!
q
我要发数据>>>:q #这里发送了q信号
[root@node10 tcp]# python3 client.py
>>>:Hi
Hi
>>>:Nice to meet you!
Nice to meet you too!
>>>:q #这里就退出
[root@node10 tcp]#

在连接一个客户端

[root@node10 tcp]# python3 client.py
>>>:Hi,I'm the other one,nice to meet you!
H,welcome,Nice to meet you too!
[root@node10 tcp]# python3 server.py
Hi
我要发数据>>>:Hi
Nice to meet you!
我要发数据>>>:Nice to meet you too!
q
我要发数据>>>:q
Hi,I'm the other one,nice to meet you! #这里是接受到的新的客户端的消息
我要发数据>>>:Hi,welcome,Nice to meet you too!
[root@node10 tcp]# python3 client.py
>>>:Hi,I'm the other one,nice to meet you!
H,welcome,Nice to meet you too! #客户端接收到的服务端消息

6 匹配最里面括号的值

import re
strvar = "(5-9+(7*7-(5-4)))"
obj = re.search("\([^()]+\)",strvar) #先匹配(),但是为了防止被分组的,使用\转义,[^()]表示必须从这个字符组挑出一个来,就使用[^()]+,就变成目前的表达式
res = obj.group()
print (res)

执行

[root@node10 python]# python3 test.py
(5-4)

036.Python的TCP语法的更多相关文章

  1. python yield from 语法

    python yield from 语法 yield语法比较简单, 教程也很多 , yield from的中文讲解很少 , python官网是这样解释的 PEP 380 adds the yield ...

  2. Python基础:语法基础(3)

    本篇主要介绍Python中一些基础语法,其中包括:标识符.关键字.常量.变量.表达式.语句.注释.模块和包等内容. 1. 标识符和关键字 1.1 标识符 标识符是变量.常量.函数.属性.类.模块和包等 ...

  3. Python的基础语法(二)

    0. 前言 接着上一篇博客的内容,我将继续介绍Python相关的语法.部分篇章可能不只是简单的语法,但是对初学者很有帮助,也建议读懂. 1. 表达式 由数字.符号.括号.变量等组成的组合. 算术表达式 ...

  4. 六. Python基础(6)--语法

    六. Python基础(6)--语法 1 ● Python3中, Unicode转字节的方法 print(bytes("李泉", encoding = 'utf-8')) prin ...

  5. 五. Python基础(5)--语法

    五. Python基础(5)--语法 1 ● break结束的是它所在的循环体, continue是让它所在的循环体继续循环 # 打印: 1 10 2 10 3 10 4 10 5 10 6 10 7 ...

  6. 四. Python基础(4)--语法

    四. Python基础(4)--语法 1 ● 比较几种实现循环的代码 i = 1 sum = 0 while i <= 10: # 循环10-1+1=10次     sum += i     i ...

  7. 三. Python基础(3)--语法

    三. Python基础(3)--语法 1. 字符串格式化的知识补充 tpl = "我是%s,年龄%d,学习进度100%" %('Arroz',18) print(tpl) # 会提 ...

  8. 二. Python基础(2)--语法

    二. Python基础(2)--语法 1.实现一个简单的登录系统 '''# 形式1 n = 1 while n < 4:     name = input("请输入姓名\n" ...

  9. 一. Python基础(1)--语法

    一. Python基础(1)--语法 1. 应用程序 1.1 什么是计算机(Computer)? 组成 ①运算器 arithmetic unit; ※ Arithmetic unit and cont ...

随机推荐

  1. 源码级深挖AQS队列同步器

    我们知道,在java中提供了两类锁的实现,一种是在jvm层级上实现的synchrinized隐式锁,另一类是jdk在代码层级实现的,juc包下的Lock显示锁,而提到Lock就不得不提一下它的核心队列 ...

  2. Unity2D项目-平台、解谜、战斗! 0.1 序言:团队、项目提出、初步设计、剧情大纲

    各位看官老爷们,这里是RuaiRuai工作室(以下简称RR社),一个做单机游戏的兴趣作坊. 本文跟大家聊一下社团内第一个游戏项目.算是从萌新项目组长的角度,从第一个里程碑的结点处,往前看总结一下项目之 ...

  3. 通过Dapr实现一个简单的基于.net的微服务电商系统(三)——一步一步教你如何撸Dapr

    目录:一.通过Dapr实现一个简单的基于.net的微服务电商系统 二.通过Dapr实现一个简单的基于.net的微服务电商系统(二)--通讯框架讲解 三.通过Dapr实现一个简单的基于.net的微服务电 ...

  4. Leedcode算法专题训练(排序)

    排序 快速排序 用于求解 Kth Element 问题,也就是第 K 个元素的问题. 可以使用快速排序的 partition() 进行实现.需要先打乱数组,否则最坏情况下时间复杂度为 O(N2). 堆 ...

  5. 【笔记】《Redis设计与实现》chapter11 AOF持久化

    11.1 AOF持久化的实现 命令追加 当AOF持久化处于开启状态时,服务器执行完一个写命令之后,会以协议格式将被执行的写明了追加到服务器状态的aof_buf缓冲区 struct redisServe ...

  6. 01- Python语言简介

    Python的简介: 创始人:Guido van Rossum(创始人) 时间:1989年 圣诞节 Python的命名:源于一个喜剧团 Monty Python Python语言排名 目前Python ...

  7. hdu4998 旋转坐标系

    题意:       一开始的时候有一个坐标系(正常的),然后有n个操作,每个操作是 x y d,意思是当前坐标系围绕x,y点逆时针旋转d度,最后让你输出三个数x y d,把这n个操作的最后结果,用一步 ...

  8. Linux下逻辑卷LVM的管理和RAID磁盘阵列

    目录 LVM 一:LVM的创建 二:LVM的拉伸 三:LVM的缩小 四:LVM的删除 五:RAID磁盘阵列的添加 LVM LVM(Logical Volume Manager) 逻辑卷管理器,可以动态 ...

  9. DLL内存加载

    动态加载dll 功能:      把一个处于内存里的dll直接加载并且使用. 用途:      免杀(静态文件查杀),外挂(防止游戏自己hook了loadlibrary等函数),以及其他. 原理:  ...

  10. [CTF]思维导向图

    [CTF]思维导向图 ---------------来自大佬的CTF思维导向图 Angel_Kitty https://www.cnblogs.com/ECJTUACM-873284962/ 给信息安 ...