一、复习
1、网络编程
软件开发架构
b/s架构
c/s架构
本质都是c/s架构
2、互联网协议
OSI七层协议
应用层
表示层
会话层
传输层
网络层
数据链路层
物理连接层
3、 物理连接层:建立物理连接传输电信号
数据链路层(以太网协议)
规定了电信号的分组方式
任何接入互联网的计算机都必须有一块网卡(有一个独一无二的编号:mac地址)
交换机:基于以太网通信特点:靠吼(一旦同时有好多电脑发送请求,交换机吼的话就会产生广播风暴)
网络层(ip协议):
规定了任何接入互联网的一台计算机都必须有一个ip地址(点分十进制)
传输层(TCP,UDP)
tcp,udp基于端口工作的协议
端口范围:0~65535
端口:能够标识一台计算机上某一时刻运行的某一款应用程序
ip+port就能够标识世界上唯一一台计算机上运行的某一款基于互联网通信的软件
TCP(流式协议,可靠协议):三次握手,四次挥手
UDP(数据报协议):
无需建立双向连接,并且传输数据不可靠,可能会出现丢包的情况
通信速度比较快,但是发送的数据不会在内存中保留
应用层:
http协议,ftp协议 二、socket(套接字)
1、基于socket实现客户端与服务端通信
服务端:
  
import socket

server = socket.socket()             #产生服务的对象
server.bind(('127.0.0.1',8080)) #绑定自己的ip+port
server.listen(5) # 半连接池 #允许的最大请求数(开客户端的次数) conn,addr = server.accept() #等待接收,conn是类的对象,addr是客户端那个人的地址 data = conn.recv(1024) #接收客户端发送的信息
print(data)
conn.send(b'hello') #回复信息 conn.close() #关闭通信连接
server.close() #关闭服务端
客户端:
import socket

client = socket.socket()         #产生客户端对象(不传参数的话,默认tcp协议)
client.connect(('127.0.0.1',8080)) #找到服务器的ip+port client.send(b'how are you ') #向服务端发送信息
data = client.recv(1024) #接收服务端回复的信息
print(data)
client.close() #关闭通信连接
2、tcp协议的特点:
如果客户端发来(‘hello’)
服务端:
conn,addr = server.accept()
data = conn.recv(4) #只能接收4个字节
print(data) #b'hell'
data = conn.recv(5) #带着第一次遗留的接收5个字节
print(data) #b'ohell'
data = conn.recv(5) #带着第二次遗留的接收5个字节
print(data) #b'ohell'
3、最终解决粘包问题
服务端:
import socket
import subprocess
import struct
import json server = socket.socket()
server.bind(('127.0.0.1',8098))
server.listen(5) while True:
conn,addr = server.accept()
while True:
try: # 当客户端人为断掉后,服务端会报错,需要捕捉异常
data = conn.recv(1024).decode('utf-8')
if len(data) == 0:break #针对Linux和Mac系统,客户端异常断开反复收空的情况
obj = subprocess.Popen(data,shell=True,stdout=subprocess.PIPE,stderr=subprocess.PIPE)
stdout = obj.stdout.read()
stderr = obj.stderr.read() # 接收客户端发送过来的指令
print(len(stdout+stderr)) header_dic = {
'filename':'cls.txt',
'len':len(stdout+stderr) # 制作自定义的字典,可以自己添加信息
}
header_bytes = json.dumps(header_dic).encode('utf-8') # 制作报头
header = struct.pack('i',len(header_bytes)) # 将需要发送给客户的数据打包成固定4个字节
conn.send(header) # 先发报头
conn.send(header_bytes) #再发字典
conn.send(stdout+stderr) #再发真实数据内容
except ConnectionResetError:
break
conn.close()
server.close() 客户端:
import socket
import struct
import json client = socket.socket()
client.connect(('127.0.0.1',8098)) while True:
msg = input('>>>:').encode('utf-8')
if len(msg) == 0:continue
client.send(msg)
header = client.recv(4) # 接收报头 # 对这个头进行解包,获取真实数据的长度
head_len = struct.unpack('i',header)[0]
head_dic = json.loads(client.recv(head_len).decode('utf-8'))
print(head_dic) # 对需要接收的数据进行循环接收
total_size = head_dic['len']
recv_size = 0
res = b''
while recv_size < total_size:
data = client.recv(1024)
res += data
recv_size += len(data)
print(res.decode('gbk'))

DAY31、socket套接字的更多相关文章

  1. day31 socket套接字编程

    为什么要有套接字编程? 在上节课的学习中,我们学习了OSI七层协议,但是如果每次进行编程时我们都需要一层一层的将各种协议使用在我们的程序中,这样编写程序实在是太麻烦了,所以为了让程序的编写更加的简单, ...

  2. java 25 - 3 网络编程之 Socket套接字

    Socket Socket套接字: 网络上具有唯一标识的IP地址和端口号组合在一起才能构成唯一能识别的标识符套接字. Socket原理机制: 通信的两端都有Socket. 网络通信其实就是Socket ...

  3. 进程、线程、socket套接字-资源大小 & 切换代价

    另,进程 & 线程的很多知识可以看这里:http://www.cnblogs.com/charlesblc/p/6135666.html 今天查了一下进程和线程的资源占用. 比如问:栈和堆的大 ...

  4. linux网络环境下socket套接字编程(UDP文件传输)

    今天我们来介绍一下在linux网络环境下使用socket套接字实现两个进程下文件的上传,下载,和退出操作! 在socket套接字编程中,我们当然可以基于TCP的传输协议来进行传输,但是在文件的传输中, ...

  5. linux网络编程-(socket套接字编程UDP传输)

    今天我们来介绍一下在linux网络环境下使用socket套接字实现两个进程下文件的上传,下载,和退出操作! 在socket套接字编程中,我们当然可以基于TCP的传输协议来进行传输,但是在文件的传输中, ...

  6. socket套接字TCP API

    socket套接字TCP API socket概念 socket又称"套接字",是计算机网络中进程间通信数据通道的一个端点.或称之为句柄.IP地址+port号就能够唯一确定一个so ...

  7. 进程间通信系列 之 socket套接字实例

    进程间通信系列 之 概述与对比   http://blog.csdn.net/younger_china/article/details/15808685  进程间通信系列 之 共享内存及其实例   ...

  8. 进程间通信系列 之 socket套接字及其实例

    进程间通信系列 之 概述与对比   http://blog.csdn.net/younger_china/article/details/15808685  进程间通信系列 之 共享内存及其实例   ...

  9. 一、网络编程-UDP传输协议及socket套接字使用

    知识点基本介绍:1.网络通信协议一般就是UDP和TCP俩种传输协议,这一章先说UDP,UDP是一种比较简单的传输协议,如qq使用的就是UDP          2.ip:ip就是标记网络中中的一台电脑 ...

  10. 网络编程初识和socket套接字

    网络的产生 不同机器上的程序要通信,才产生了网络:凡是涉及到倆个程序之间通讯的都需要用到网络 软件开发架构 软件开发架构的类型:应用类.web类 应用类:qq.微信.网盘.优酷这一类是属于需要安装的桌 ...

随机推荐

  1. 一致性哈希算法(consistent hashing)(转载)

    转载请说明出处:http://blog.csdn.net/cywosp/article/details/23397179     一致性哈希算法在1997年由麻省理工学院提出的一种分布式哈希(DHT) ...

  2. python时间戳、日期、时间转换

    1.str转时间戳 # 字符类型的时间 tss1 = '2013-10-10 23:40:00' # 转为时间数组 timeArray = time.strptime(tss1, "%Y-% ...

  3. win 10+ iis 10 部署.net core 1.1 web api

    今天上午部署了wcf,部署了好久,一直没有部署好,最后找到了dudu的部署方法,结果中午吃饭的时候成功了,这是链接:http://www.cnblogs.com/dudu/p/3328066.html ...

  4. visjs使用小记-2.option参数注释说明

    对部分参数进行中文说明,后续补充 var options = { nodes:{//节点配置 borderWidth: 1,//节点边框的宽度,单位为px borderWidthSelected: 2 ...

  5. 关于启动MongDB的mongod.exe文件闪退的问题

    昨天学mongdb的时候,遇到了mongod.exe闪退的问题,解决办法很简单: 你可以不执行mongod.exe,直接用命令行操作 在你安装mongdb的盘的根目录下创建一个data文件夹,一定要在 ...

  6. 工具类: 用于模拟HTTP请求中GET/POST方式

    package com.jarvis.base.util; import java.io.BufferedReader; import java.io.IOException; import java ...

  7. Reducing File Size

    [Reducing File Size] 1.Unity strips out unused assets. The amount of assets in your project folder d ...

  8. Python基础:面向对象基础(二) 继承

    子类在继承的时候,在定义类时,小括号()中为父类的名字,父类的属性.方法,会被继承给子类,Python中允许多继承. 多继承 # 父类 Master class Master(object): def ...

  9. .net中delegate的使用

    js中的写法: var GetEntityList = function(pParameter){ var list =[]; return list; }; var aEntityList = Ge ...

  10. jmeter 读取mysql数据库

    业务背景 当我们用jmeter进行压测,或者造数据的时候,我们可能希望每次请求的参数都是随机的.如果从一个文件里读取,很难达到要求.jmeter提供了一套读取数据库的组件,能满足部分要求.但性能不好, ...