day26-socket(server和client通信)


# socket是应用层与TCP/IP协议通信的中间软件抽象层,它是一组接口。它把复杂的TCP/IP协议隐藏到socket
#接口的后面,让socket去组织数据,以符合指定的协议。
# socket是一个模块,使用它来建立两个程序之间的连接和通信。也可以把socket看做是ip+port,因为ip标识
#互联网中一台主机的位置,而port标识这台主机上的一个应用程序,只要确立ip和port就可以找到一个应用程序,
#并且使用socket模块来与这个应用程序通信。
# 先启动server,等待client发信息。
#网络传输的是bytes,recv接收之后,需要decode解码为str。
#encode编码,把str转化为bytes。 # 一、基于TCP的socket服务:
# 1、server服务端:
# 1.1
import socket
sk = socket.socket() #买手机--创建套接字
# sk.setsockopt(socket.SOL_SOCKET,socket.SO_REUSEADDR,1)避免服务重启的时候报address already in use
sk.bind(('127.0.0.1',8080)) #绑定手机卡--绑定端口:sk.bind(('ip','port')),bind(元祖)
# 127.0.0.1是本机的回环地址,用于本机内部应用程序的通信。
sk.listen() #监听,等待有人给我打电话--侦听客户请求
conn,addr = sk.accept() #接收到别人的电话,--接受客户端连接
# 得到了连接conn(connection),和别人的地址addr(address)
#接收、发送--recv、send
ret = conn.recv(1024) #听别人说话,--接收客户端信息
# 接收1024个字节,如果接收更长的信息可以填写2048或其他更大的数字,recv(receive)接收
print(ret.decode('utf-8'))
conn.send(b'hi,client') #和别人说话,必须传一个bytes类型。--向客户端发送信息。b'hi,client'相当于'hi,client'.encode('utf-8'))
ret = conn.recv(1024)
print(ret.decode('utf-8'))#接收的是bytes,要解码为utf-8
conn.send(bytes('你也不错',encoding = 'utf-8')) #conn.send('你也不错'.encode('utf-8')) conn.close() #挂电话--关闭客户端套接字
sk.close() #关手机--关闭服务器套接字 # 1.2 不停跟client聊天,直到说bye才结束。
import socket
sk = socket.socket()
sk.bind(('127.0.0.1',8082))
sk.listen()
conn,addr = sk.accept() while True:
ret = conn.recv(1024).decode('utf-8')
if ret == 'bye':
print(ret)
conn.send(b'bye')
break
print(ret)
info = input('>>>')
conn.send(bytes(info,encoding = 'utf-8'))#conn.send(info.encode('utf-8')) conn.close()
sk.close() # 2、client客户端:
# 2.1
import socket
sk = socket.socket() #买手机
sk.connect(('127.0.0.1',8080))#拨号,连接别人的地址和端口 sk.send(b'hello,server') #和别人说话
ret = sk.recv(1024) #听别人说话
print(ret.decode('utf-8'))
sk.send(bytes('你很好',encoding = 'utf-8'))
ret = sk.recv(1024)
print(ret.decode('utf-8')) sk.close() #关手机 # 2.2 不停跟server聊天,直到说bye才结束。
import socket
sk = socket.socket()
sk.connect(('127.0.0.1',8082)) while True:
info = input('>>>')
sk.send(bytes(info,encoding = 'utf-8'))
ret = sk.recv(1024).decode('utf-8')
print(ret)
if ret == 'bye':
sk.send(b'bye')
break
sk.close() # 二、基于UDP的socket服务:不需要连接。
# 1.1 server服务端:
import socket
sk = socket.socket(type=socket.SOCK_DGRAM)
sk.bind(('127.0.0.1',9000)) #没有listen监听和accept接收连接
ret,addr = sk.recvfrom(1024) #接收client的addr是元祖,元祖没有decode属性,所以这里不能写sk.recvfrom(1024).decode('utf-8')
print(ret.decode('utf-8'))
print(addr)#('127.0.0.1',63508),是client的地址。
sk.sendto(bytes('你好client',encoding='utf-8'),addr) #发送的时候需要填写client的addr地址 sk.close() # 1.2 client客户端:
import socket
sk = socket.socket(type=socket.SOCK_DGRAM)
ip_port = ('127.0.0.1',9000) #server的地址和端口 sk.sendto(bytes('你好server',encoding='utf-8'),ip_port)#发送的时候需要把自己的地址一起发给server
ret,addr = sk.recvfrom(1024)#addr就是ip_port
print(ret.decode('utf-8')) sk.close() # 2.1 一个服务器端 对 两个客户端:例如qq聊天
#服务器端:
import socket
sk = socket.socket(type=socket.SOCK_DGRAM)
sk.bind(('127.0.0.1',9000))
while True:
ret,addr = sk.recvfrom(1024)
print(ret.decode('utf-8'))
info = input('>>>')
sk.sendto(bytes(info,encoding='utf-8'),addr)
sk.close() #客户端1:
import socket
sk = socket.socket(type=socket.SOCK_DGRAM)
ip_port = ('127.0.0.1',9000)
while True:
info = input('>>>')
sk.sendto(bytes(('\033[31mclient1:%s\033[0m'%info).encode('utf-8')),ip_port)
ret,addr = sk.recvfrom(1024)
print(ret.decode('utf-8'))
sk.close() #客户端2:
import socket
sk = socket.socket(type=socket.SOCK_DGRAM)
ip_port = ('127.0.0.1',9000)
while True:
info = input('>>>')
sk.sendto(bytes(('\033[31mclient2:%s\033[0m'%info).encode('utf-8')),ip_port)
ret,addr = sk.recvfrom(1024)
print(ret.decode('utf-8'))
sk.close()
day26-socket(server和client通信)的更多相关文章
- Winsock网络编程笔记(3)----基于UDP的server和client
在上一篇随笔中,对Winsock中基于tcp面向连接的Server和Client通信进行了说明,但是,Winsock中,Server和Client间还可以通过无连接通信,也就是采用UDP协议.. 因此 ...
- Winsock网络编程笔记(2)----基于TCP的server和client
今天抽空看了一些简单的东西,主要是对服务器server和客户端client的简单实现. 面向连接的server和client,其工作流程如下图所示: 服务器和客户端将按照这个流程就行开发..(个人觉得 ...
- Android简单实现Socket通信,client连接server后,server向client发送文字数据
案例实现的是简单的Socket通信,当client(Androidclient)连接到指定server以后,server向client发送一句话文字信息(你能够拓展其他的了) 先看一下服务端程序的实现 ...
- netty4.0 Server和Client的通信
netty4.0 Server和Client的通信 创建一个maven项目 添加Netty依赖 <dependency> <groupId>io.netty</group ...
- (填坑系列) 用aio写server与client进行通信的坑
最近闲来无事,就估摸着自己写个“服务注册中心”来玩,当然因为是个人写的,所以一般都是简洁版本. 代码地址在:https://gitee.com/zhxs_code/my-service-registe ...
- C Socket Programming for Linux with a Server and Client Example Code
Typically two processes communicate with each other on a single system through one of the following ...
- java 记录一下socket的server与client
package com.test.server; import java.io.IOException; import java.net.ServerSocket; import org.apache ...
- 用XMLRPC开服务进行server/client通信
本文讲一下怎样用python的xmlrpc开服务,进行server/client的通信. 应用场景:1)需多client訪问应用程序给予应答情况--网页服务. 2)数据极大,希望载入一次.后面仅仅用 ...
- C语言 linux环境基于socket的简易即时通信程序
转载请注明出处:http://www.cnblogs.com/kevince/p/3891033.html ——By Kevince 最近在看linux网络编程相关,现学现卖,就写了一个简易 ...
随机推荐
- AD软件将PCB中的元器件旋转45度
- 为什么ApplePay在中国一直火不起来?
今年7月,易观发布<中国第三方移动支付市场2018年第1季度监测报告>.报告显示,2018年第一季度支付宝以53.76%的市场份额占据移动支付头把交椅,腾讯金融(微信支付)则以38.95% ...
- 代码review还是需要再仔细点-一次crash异常分析的总结
版本发布之后,外网新增了一些crash, 从mini dump看,的确是有异常的,619行crash了. 代码如下: 奔溃的地方如下 可以看到是Zip add的时候指针空了, 为什么呢? 结合代码,可 ...
- nexus3安装 - CentOS7环境
nexus3安装 - CentOS7环境 使用nexus3管理docker镜像,配合rancher进行部署. 建资料卷 资料卷默认地址:/var/lib/docker/volumes/资料卷名/_da ...
- Codeforces Round #619 (Div. 2)E思维+二维RMQ
题:https://codeforces.com/contest/1301/problem/E 题意:给个n*m的图形,q个询问,每次询问问询问区间最大的合法logo的面积是多少 分析:由于logo是 ...
- __init__.py在Python中的用处
1.Python中的package定义很简单,其层次结构与程序所在目录的层次结构相同, 这一点与Java类似,唯一不同的地方在于,python中的package必须包含一个__init__.py的文件 ...
- IO流的学习以及统计次数最多的单词
IO流: 处理数据类型:字节流(InputStream OutputStream)和字节流(Reader Writer) 数据流向不同:输入流和输出流(FileInputStream File ...
- 美团:WSDM Cup 2019自然语言推理任务获奖解题思路
WSDM(Web Search and Data Mining,读音为Wisdom)是业界公认的高质量学术会议,注重前沿技术在工业界的落地应用,与SIGIR一起被称为信息检索领域的Top2. 刚刚在墨 ...
- EL表达式和JSTL(二)——BeanUtils工具
BeanUtils工具 大对数人习惯使用JavaBean的get和set方法来获取和设置JavaBean的属性,但是在Java EE编程的过程中,会经常从配置文件中读取数据,但是从配置文件中读取的数据 ...
- tensorflow模型
图像模型 YOLOv3 , 地址 https://pjreddie.com/darknet/yolo/ vgg , 参考 https://github.com/tensorflow/models/bl ...