OSI 模型介绍

应用层 -- 对接受的数据进行解释、加密与解密、压缩与解压缩

会话层 -- 通过传输层(端口号: 传输端口和接受端口) 建立数据传输的通路

传输层 -- 定义了一些传输数据的协议和端口号(www端口80等),如:TCP

网络层 -- 主要将从下层接收到的数据进行IP地址(例:192.168.0.1)的封装与解封装

数据链路层 -- 主要将从物理层接收的数据进行MAC地址的封装与解封装

物理层 -- 主要定义物理设备标志,如往昔的接口类型,跟踪传输介质的传输速率等

TCP/IP协议

参考模型把所有的TCP/IP系列协议归类到四个抽象层中

应用层 -- TFTP,HTTP,SNMP,FTP,SMTP,DNS,Telnet 等等

传输层 -- TCP,UDP

网络层 -- IP,ICMP,OSPF,EIGRP,IGMP

数据链路层 -- SLIP,CSLIP,PPP,MTU

Socket 通信流程

相关方法及参数介绍

  1. family=AF_INET: 服务器之间的通信
  2. family=AF_UNIX: Unix 不同进程间通信
  3. sk.bind(address)
  4. #s.bind(address) 将套接字绑定到地址。address地址的格式取决于地址族。在AF_INET下,以元组(host,port)的形式表示地址。
  5. sk.listen(backlog)
  6. #开始监听传入连接。backlog指定在拒绝连接之前,可以挂起的最大连接数量。
  7. #backlog等于5,表示内核已经接到了连接请求,但服务器还没有调用accept进行处理的连接个数最大为5
  8. #这个值不能无限大,因为要在内核中维护连接队列
  9. sk.setblocking(bool)
  10. #是否阻塞(默认True),如果设置False,那么accept和recv时一旦无数据,则报错。
  11. sk.accept()
  12. #接受连接并返回(conn,address),其中conn是新的套接字对象,可以用来接收和发送数据。address是连接客户端的地址。
  13. #接收TCP 客户的连接(阻塞式)等待连接的到来
  14. sk.connect(address)
  15. #连接到address处的套接字。一般,address的格式为元组(hostname,port),如果连接出错,返回socket.error错误。
  16. sk.connect_ex(address)
  17. #同上,只不过会有返回值,连接成功时返回 0 ,连接失败时候返回编码,例如:10061
  18. sk.close()
  19. #关闭套接字
  20. sk.recv(bufsize[,flag])
  21. #接受套接字的数据。数据以字符串形式返回,bufsize指定最多可以接收的数量。flag提供有关消息的其他信息,通常可以忽略。
  22. sk.send(string[,flag])
  23. #将string中的数据发送到连接的套接字。返回值是要发送的字节数量,该数量可能小于string的字节大小。即:可能未将指定内容全部发送。
  24. sk.sendall(string[,flag])
  25. #将string中的数据发送到连接的套接字,但在返回之前会尝试发送所有数据。成功返回None,失败则抛出异常。
  26. #内部通过递归调用send,将所有内容发送出去。

简单的通信(client 端发送消息,server 端接收,一发一收)

  1. # server 端
  2. import socket
  3. sk = socket.socket()
  4. address=('127.0.0.1', 8000)
  5. sk.bind(address)
  6. sk.listen(3)
  7. print('waiting....')
  8. conn, addr = sk.accept()
  9. while 1:
  10. data = conn.recv(1024) # server 端通过 conn 接收和发送数据
  11. print('.....',str(data, 'utf8'))
  12. if not data: break
  13. inp = input('>>>')
  14. conn.send(bytes(inp,'utf8'))
  15. sk.close()
  16. # client 端
  17. import socket
  18. sk = socket.socket()
  19. address = ('127.0.0.1', 8000)
  20. sk.connect(address)
  21. while True:
  22. inp = input('>>>')
  23. if inp == 'exit':
  24. break
  25. sk.send(bytes(inp, 'utf8')) # client 端通过 sk 接收和发送数据
  26. data = sk.recv(1024)
  27. print(str(data,'utf8'))
  28. sk.close()

简单的通信(server 持续监听)

  1. # server 端
  2. import socket
  3. sk = socket.socket()
  4. address=('127.0.0.1', 8000)
  5. sk.bind(address)
  6. sk.listen(3)
  7. print('waiting....')
  8. while 1:
  9. conn, addr = sk.accept()
  10. print(addr)
  11. while 1:
  12. try:
  13. data = conn.recv(1024)
  14. except Exception:
  15. break
  16. print('.....',str(data, 'utf8'))
  17. inp = input('>>>')
  18. conn.send(bytes(inp,'utf8'))
  19. sk.close()
  20. # client 端
  21. import socket
  22. sk = socket.socket()
  23. address = ('127.0.0.1', 8000)
  24. sk.connect(address)
  25. while True:
  26. inp = input('>>>')
  27. if inp == 'exit':
  28. break
  29. sk.send(bytes(inp, 'utf8'))
  30. data = sk.recv(1024)
  31. print(str(data,'utf8'))
  32. sk.close()

使用python执行命令

  1. import subprocess
  2. a = subprocess.Popen('dir', shell=True, stdout=subprocess.PIPE)
  3. print(str(a.stdout.read(),'gbk')) # windows 机器默认编码为 gbk 所以输出需要解码为 gbk

bytes编码 与 str编码相互转换

  1. str : unicode
  2. bytes : 十六进制
  3. s = 'hello,陈先生'
  4. print(type(s)) # <class 'str'>
  5. b = bytes(s, 'utf8') # str 编码成 bytes
  6. print(type(b)) # <class 'bytes'>
  7. print(b) # b'hello,\xe9\x99\x88\xe5\x85\x88\xe7\x94\x9f
  8. b2 = s.encode('utf8') # str 编码成 bytes
  9. print(type(b2)) # <class 'bytes'>
  10. print(b) # b'hello,\xe9\x99\x88\xe5\x85\x88\xe7\x94\x9f
  11. s1 = str(b2, 'utf8') # bytes 解码成 str
  12. print(s1) # hello,陈先生
  13. s2 = b2.decode('utf8') # bytes 解码成 str
  14. print(s2) # hello,陈先生

参考:http://www.cnblogs.com/yuanchenqi/articles/5692716.html

Python简单的网络编程的更多相关文章

  1. python高级之网络编程

    python高级之网络编程 本节内容 网络通信概念 socket编程 socket模块一些方法 聊天socket实现 远程执行命令及上传文件 socketserver及其源码分析 1.网络通信概念 说 ...

  2. 第六篇:python高级之网络编程

    python高级之网络编程   python高级之网络编程 本节内容 网络通信概念 socket编程 socket模块一些方法 聊天socket实现 远程执行命令及上传文件 socketserver及 ...

  3. Python之路 - 网络编程之粘包

    Python之路 - 网络编程之粘包 粘包

  4. Python之路 - 网络编程初识

    Python之路 - 网络编程初识 前言

  5. python之Socket网络编程

    什么是网络? 网络是由节点和连线构成,表示诸多对象及其相互联系.在数学上,网络是一种图,一般认为专指加权图.网络除了数学定义外,还有具体的物理含义,即网络是从某种相同类型的实际问题中抽象出来的模型.在 ...

  6. 【循序渐进学Python】15.网络编程

    Python 内置封装了很多常见的网络协议的库,因此Python成为了一个强大的网络编程工具,这里是对Python的网络方面编程的一个简单描述. 1. 常用的网络设计模块 在标准库中有很多网络设计相关 ...

  7. 周末班:Python基础之网络编程

    一.楔子 你现在已经学会了写python代码,假如你写了两个python文件a.py和b.py,分别去运行,你就会发现,这两个python的文件分别运行的很好.但是如果这两个程序之间想要传递一个数据, ...

  8. Python 基础之----网络编程

    阅读目录 一 客户端/服务端架构 二 osi七层 三 socket层 四 socket是什么 五 套接字发展史及分类 六 套接字工作流程 七 基于TCP的套接字 八 基于UDP的套接字 九 粘包现象 ...

  9. python之路-----网络编程

    一:客户端/服务端j架构(C/S架构) 在生活中,最常见的C/S架构即是APP和网页服务器这个架构.Client和Server之间利用网络来进行通信,客户端和服务器端的程序不同,用户的程序主要在客户端 ...

随机推荐

  1. [wxgl] load image fail

    微信小游戏 let loader = new THREE.TextureLoader() let texture = loader.load('./images/bullet.png') 报错 参考 ...

  2. Akka-Cluster(3)- ClusterClient, 集群客户端

    上篇我们介绍了distributed pub/sub消息传递机制.这是在同一个集群内的消息共享机制:发布者(publisher)和订阅者(subscriber)都在同一个集群的节点上,所有节点上的Di ...

  3. 使用Lucene-Spatial实现集成地理位置的全文检索

    Lucene通过Spatial包提供了对基于地理位置的全文检索的支持,最典型的应用场景就是:“搜索中关村附近1公里内的火锅店,并按远近排序”.使用Lucene-Spatial添加对地理位置的支持,和之 ...

  4. 微信小程序如何套用iconfont

    前言 如果你在开发微信时,没有图标的话,可以到http://www.iconfont.cn/ 官方下使用图标,那么我们去使用一些吧,到官方网址下点击使用~ 下载代码即可使用,看看下载的文件吧. 如图可 ...

  5. Spring中新建记录后返回自增主键的处理方法

    接手一个旧系统改造的过程,要插入后立即返回自增值,不能重构guid类型主键,Spring提供了很优美的机制. Spring利用GeneratedKeyHolder,提供了一个可以返回新增记录对应主键值 ...

  6. 对于python setup.py install安装的包如何卸载

    easy_install 安装 卸载命令 easy_install -m package-name setup.py安装 帮助你纪录安装细节方便你卸载 python setup.py install ...

  7. Jquery 动态追加控件并获取值

    先展示通过动态添加控件的结果: 实现步骤: 1.引用js文件 <script src="Script/jquery-1.5.1.min.js" type="text ...

  8. 第一篇:SpringBoot2.0简单介绍

    距离Spring Boot1.0发布已经4年了,今年3月份SpringBoot2.0正式发布.让我们一起来了解一下它. Spring Boot主要依赖于Spring,整合了很多框架的使用方式,帮助开发 ...

  9. NetMQ 发布订阅模式 Publisher-Subscriber

    第一部分引用于:点击打开 1:简单介绍 PUB-SUB模式一般处理的都不是系统的关键数据.发布者不关注订阅者是否收到发布的消息,订阅者也不知道自己是否收到了发布者发出的所有消息.你也不知道订阅者何时开 ...

  10. Java和Python分别实现直接选择排序

    1.基本思想 将指定排序位置与其他数组元素分别对比,如果满足条件就进行交换.个人理解其实就是每趟循环从数组里选一个最大的值(最小的值)放到数组最后(最前). 2.算法实现 这里以每趟循环从数组中选择一 ...