Python网络编程02 /基于TCP、UDP协议的socket简单的通信、字符串转bytes类型
Python网络编程02 /基于TCP、UDP协议的socket简单的通信、字符串转bytes类型
1. socket / 套接字
1.socket是处于应用层与传输层之间的抽象层,它是一组操作起来非常简单的接口(接收数据)此接口接收数据后,交由操作系统
2.为什么存在socket抽象层
如果直接与操作系统交互非常麻烦,繁琐,socket对这些繁琐的操作高度的封装,简化
3.socket在Python中就是一个模块
2. 基于TCP协议的socket简单通信
客户端(client)
import socket
# 表示基于TCP进行连接
client = socket.socket(socket.AF_INET,socket.SOCK_STREAM)
# 连接的IP地址以及端口
client.connect(("127.0.0.1",8888)) # 必须是元组 # 给服务端发送内容,必须用二进制进行发送消息
date = input("请输入:")
client.send(date.encode("utf-8")) # 接收服务端发送的内容,允许接收服务端至多1024字节
from_server_date = client.recv(1024) # 打印服务端发过来的消息
print(f"来自服务端的消息:{from_server_date}") client.close()
服务端(server)
import socket # 默认基于TCP协议的socket
server = socket.socket(socket.AF_INET,socket.SOCK_STREAM)
# 绑定IP地址和端口
server.bind(("127.0.0.1",8888))
# 开机监听
server.listen(5) # 服务端可以接收N个链接,但是只能同一时刻回应五个请求. # 等待连接
conn,addr = server.accept() # 阻塞(等待客户端的连接) print(conn,addr) # 打印数据传输的通道、客户端的ip 端口,conn代表两条管道 from_client_data = conn.recv(1024) # 至多接收1024个字节 阻塞,超过1024分批接收 print(f'来自客户端的消息:{from_client_data}') # 打印客户端发送的内容 conn.send(from_client_data.upper()) # 给客户端发送内容 conn.close() # 关闭通道 server.close() # 关机
3. 基于UDP协议的socket通信
服务端
import socket
# 基于UDP协议的连接
server = socket.socket(socket.AF_INET,socket.SOCK_DGRAM)
# 绑定IP和端口
server.bind(('192.168.14.198',9000)) while 1:
# 等待接收消息
from_client_data = server.recvfrom(1024) # 阻塞,等待客户来消息
# 打印客户端的IP以及消息
print(f'\033[1;35;0m来自客户端{from_client_data[1]}: {from_client_data[0].decode("utf-8")} \033[0m')
# 给客户端回消息
to_client_data = input('>>>').strip()
server.sendto(to_client_data.encode('utf-8'),from_client_data[1]) # 1. 基于UDP协议的socket无须建立管道,先开启服务端或者客户端都行.
# 2. 基于UDP协议的socket接收一个消息,与发送一个消息都是无连接的.
# 3. 只要拿到我的IP地址和端口就都可以给我发消息,我按照顺序接收消息.
客户端
import socket
# 基于UDP协议的连接
client = socket.socket(socket.AF_INET,socket.SOCK_DGRAM) while 1:
# 无需建立管道,通过服务的IP和端口进行发送消息
to_server_data = input('>>>:').strip()
client.sendto(to_server_data.encode('utf-8'),('127.0.0.1',9000))
# 接收服务端返回的消息
data,addr = client.recvfrom(1024)
# 打印服务端的IP以及返回的消息
print(f'来自服务端{addr}消息:{data.decode("utf-8")}')
4. 字符串转bytes类型
在ASCII表中的字符
s1 = 'hello'
s2 = b'hello'
print(s1.encode('utf-8')) # b'hello' # 对于在ASCII表中的字符可以通过在字符前面加b'',转换成bytes类型
非ASCII表中的字符
s = '你好'
print(s.encode('utf-8')) # 对于非ASCII表中的字符,只能通过encode ,转化成bytes类型
Python网络编程02 /基于TCP、UDP协议的socket简单的通信、字符串转bytes类型的更多相关文章
- 基于TCP/UDP协议的socket
基于TCP协议的socket tcp是基于链接的,必须先启动服务端,然后再启动客户端去链接服务端 server端 import socket sk = socket.socket() sk.bind( ...
- 《Python网络编程》学习笔记--UDP协议
第二章中主要介绍了UDP协议 UDP协议的定义(转自百度百科) UDP是OSI参考模型中一种无连接的传输层协议,它主要用于不要求分组顺序到达的传输中,分组传输顺序的检查与排序由应用层完成,提供面向事务 ...
- 基于tcp/udp协议的套接字通信
目录 一.套接字分类 二.套接字的工作流程 三.基于tcp协议的套接字 四.基于udp协议的套接字 一.套接字分类 1.基于文件类型的套接字家族:AF_UNIX 2.基于网络类型的套接字家族:AF_I ...
- Python进阶(1)_Socket网络编程(基于tcp的socket)
网络协议参考:http://www.cnblogs.com/hedeyong/p/6889774.html 一.TCP/IP五层模型 学习socket一定要先学习互联网协议: 1.首先:本节课程的目标 ...
- Android网络编程系列 一 TCP/IP协议族
在学习和使用Android网路编程时,我们接触的仅仅是上层协议和接口如Apache的httpclient或者Android自带的httpURlconnection等等.对于这些接口的底层实现我们也有必 ...
- TCP/IP网络编程之基于TCP的服务端/客户端(二)
回声客户端问题 上一章TCP/IP网络编程之基于TCP的服务端/客户端(一)中,我们解释了回声客户端所存在的问题,那么单单是客户端的问题,服务端没有任何问题?是的,服务端没有问题,现在先让我们回顾下服 ...
- python 之 网络编程(基于TCP协议的套接字通信操作)
第八章网络编程 8.1 基于TCP协议的套接字通信 服务端套接字函数 s.bind() 绑定(主机,端口号)到套接字 s.listen() 开始TCP监听 s.accept() 被动接受TCP客户的连 ...
- python网络编程(通过tcp或者udp协议通信)
1.基于tcp协议传送文件: 客户端: import socketimport osimport jsonimport structclient = socket.socket()client.con ...
- 网络编程之基于tcp和udp的套接字
一 udp协议网络编程 DNS:将域名解析成ip地址 SOCK_DGRAM:数据报协议,也是udp协议 udp协议的网络编程的一些用法: recvfrom:接收消息,接收的时一个元组,元组里面的元 ...
随机推荐
- [转] 图解单片机下载程序电路原理之USB转串口线、CH340、PL2303、MAX232芯片的使用
点击阅读原文 目前为止,我接触单片机已有不少时日,从选择元器件.原理图.PCB.电路硬件调试.软件开发也算小有心得 .单片机软件开发里面第一步当属下载程序了,如果这一步都有问题,那么后面的一切便无从谈 ...
- java特性 JDK JRE JVM
1简单性 2可移植性性(跨平台) 3面向对象 4高性能 5分布式 6动态性 7多线程 8安全性JDK:java开发工具 . JRE:JDK:java运行环境 . JVM:JDK:java虚拟机
- (八)postman请求的form-data、x-www-form-urlencoded、raw、binary的区别
原文链接:https://blog.csdn.net/jiadajing267/article/details/87883725 1.form-data 等价于http请求中的multipart/fo ...
- Homebrew命令总结
brew又叫homebrew,是macos上的一个包管理工具,能够在mac中方便的进行包管理,类似于ubuntu系统下的apt-get,记得自己第一次接触brew是为了在mac上安装一个独立绿色的视频 ...
- frp多层socks代理+端口映射
一.首先在公网上配置服务端(frps.ini) [common] bind_addr = xx.xx.xx.xx #公网vps的ip bind_port = 7000 二.配置客户端frpc. i ...
- 使用Kubeflow构建机器学习流水线
在此前的文章中,我已经向你介绍了Kubeflow,这是一个为团队设置的机器学习平台,需要构建机器学习流水线. 在本文中,我们将了解如何采用现有的机器学习详细并将其变成Kubeflow的机器学习流水线, ...
- redis配置文件中slave-serve-stale-data的解释
redis.conf文件中可以看到slave-serve-stale-data这个参数,作用是什么? 原文解释: # When a slave loses its connection with th ...
- 基于领域驱动设计(DDD)超轻量级快速开发架构(二)动态linq查询的实现方式
-之动态查询,查询逻辑封装复用 基于领域驱动设计(DDD)超轻量级快速开发架构详细介绍请看 https://www.cnblogs.com/neozhu/p/13174234.html 需求 配合Ea ...
- synchronized与锁升级
1 为什么需要synchronized? 当一个共享资源有可能被多个线程同时访问并修改的时候,需要用锁来保证数据的正确性.请看下图: 线程A和线程B分别往同一个银行账户里面添加货币,A线程从内存中读取 ...
- 08.利用Easymock测试简单的servlet
1.首先导入需要使用的servlet的jar包 接下来我们编写一个登陆的servlet package com.fjnu.service; import java.net.HttpRetryExcep ...