- ubuntu12.04环境下使用kvm ioctl接口实现最简单的虚拟机
- Ubuntu 通过无线网络安装Ubuntu Server启动系统后连接无线网络的方法
- 在Ubuntu上搭建网桥的方法
- ubuntu 虚拟机上网方式及相关配置详解
CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.
这篇CFSDN的博客文章Python实现socket库网络通信套接字由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.
Socket 套接字:通讯端点 简介 。
socket起源于Unix,而Unix/Linux基本哲学之一就是“一切皆文件”,对于文件用【打开】【读写】【关闭】模式来操作。socket就是该模式的一个实现,socket即是一种特殊的文件,一些socket函数就是对其进行的操作(读/写IO、打开、关闭).
Socket 是任何一种计算机网络通讯中最基础的内容。Socket通讯一般用户C/S结构系统的网络通讯.
Socket 网络通讯是基于TCP(传输控制协议)或UDP(用户数据报协议)两种协议通讯,所以有 面向连接(TCP )与无连接(UDP ) 两种通讯方式.
Python 要创建TCP 套接字就得在创建的时候,指定套接字类型为SOCK_STREAM,它使用 TCP/IP通讯协议.
socket库提供了一个底层C API,可以使用BSD套接字接口实现网络通信。它包括socket类,用于处理具体的数据通道,还包括用来完成网络相关任务的函数,如将一个服务器名转换为一个地址以及格式化数据以便在网络上发送.
套接字是程序在本地或者通过互联网来回传递数据时所用通信通道的一个端点.
套接字有2个主要属性用于控制如何发送数据:地址簇(address family)控制所用的OSI网络层协议;套接字类型(socket type)控制传输层协议。(参考《计算机网络》7层协议) 。
Python支持3个地址簇:
AF_INET:用于IPv4寻址。IPv4长度为4个字节,通常表示为4个数的序列,每个字节对应一个数,用点号分割(如121.63.0.243)。这些值通常被称为IP地址。目前IPv4依旧还是主流。 AF_INET6:用于IPv6寻址。目前IPv6已经小范围应用,它支持128位地址和通信流调整,还支持IPv4不支持的一些路由特性。 AF_UNIX:用于UNIX域套接字(UDS)的地址簇,这是一种POSIX兼容系统上的进程间通信协议。UDS的实现通常允许操作系统直接从进程向进程间传递数据,而不用通过网络栈。这比使用AF_INET更高效,但是由于要用到文件系统作为寻址的命令空间,所以UDS仅限于同一个系统上的进程。套接字类型有两种:
SOCK_DGRAM:面向消息的数据报传输,数据报套接字通常与UDP关联,即用户数据报协议。这些套接字能提供不可靠的消息传送。 SOCK_STREAM:面向流的传输,与TCP相关,即传输控制协议。它们可以在客户和服务器之间提供字节流,通过超时管理,重传和其他特性确保提供消息传送或失败通知。大多数应用协议(如HTTP)都建立在TCP基础上,因为这样更容易创建自动处理消息排序和传送的复杂应用.
UDP通常用于顺序不太重要的协议(如DNS交换)。UDP与TCP都支持IPv4与IPv6.
socket库包含一些与网络上的域名服务交互的函数,比如解析域名为IP地址可以用到gethostbyname_ex(),示例如下:
import sockethost_str = [ 'www.baidu.com', 'cloud.tencent.com', 'www.csdn.net']for host in host_str: try: name, aliases, addresses = socket.gethostbyname_ex(host) print(host) print("主机名:", name) print("所有别名:", aliases) print("所有可用IP地址:", addresses) except socket.error as msg: print(host, msg)
运行之后,效果如下:
gethostbyname_ex:该函数返回3个参数,主机名,别名,以及解析能跳转到当前主机的IP地址.
gethostbyname:类似的函数,只返回当前主机的IP地址.
socket库提供getservbyname()函数用于查找网络服务的端口号和标准名,示例如下所示:
import socketfrom urllib.parse import urlparseurl_str = [ 'https://www.baidu.com', 'https://www.csdn.net', 'smtp://smtp.qq.com',]for url in url_str: try: parsed_url = urlparse(url) port = socket.getservbyname(parsed_url.scheme) print(url) print("端口号:", port) except socket.error as msg: print(url, msg)
运行之后,效果如下:
当然,其实最有用的并不是给定一个链接去查询端口号,而是逆向操作。(因为标准化服务端口号一般都是固定的) 。
socket库提供getservbyport()函数用于完成逆向的服务端口查找,示例代码如下所示:
import socketurl = '{}://smtp.qq.com'.format(socket.getservbyport(25))print(url)
运行之后,效果如下:
socket库还可以使用getprotobyname()函数获取分配给一个传输协议的端口号,示例如下:
import socket#获取匹配开头字符串的所有属性值def getConstants(prefix): return { getattr(socket, n): n for n in dir(socket) if n.startswith(prefix) }ipproto_str = getConstants("IPPROTO_")for agree in ['tcp', 'udp']: num = socket.getprotobyname(agree) name = ipproto_str[num] print(name, num)
运行之后,效果如下:
对于协议码,在程序定义中一般都是标准化常量,这就是意味着,它们的常量名都有一定的规律,而socket协议码前缀是IPPROTO_.
getaddrinfo()函数用于将一个服务的基本地址转换为一个元组列表,其中包含建立一个连接所需要的全部信息。比如其网络簇与协议等,示例如下:
import socket# 获取匹配开头字符串的所有属性值def getConstants(prefix): return { getattr(socket, n): n for n in dir(socket) if n.startswith(prefix) }ipproto_str = getConstants("IPPROTO_")family_str = getConstants("AF_")type_str = getConstants("SOCK_")for response in socket.getaddrinfo('www.csdn.net', 'http', family=socket.AF_INET, type=socket.SOCK_STREAM, proto=socket.IPPROTO_TCP, flags=socket.AI_CANONNAME): family, socktype, ipproto, canonname, sockaddr = response print("地址簇: ", family_str[family]) print("套接字类型: ", type_str[socktype]) print("协议码: ", ipproto_str[ipproto]) print("主机规范名: ", canonname) print("ip地址与端口号:", sockaddr)
运行之后,效果如下:
这里如果只用socket.getaddrinfo(‘www.csdn.net', ‘http'),表示不需要过滤任何连接信息,但大型的网站一般都有几个IP或者域名跳转到主页的.
所以通过后面的参数,可以筛选自己需要的链接信息.
其中,最后一个参数socket.AI_CANONNAME表示如果主机有别名,那么结果中会包含服务器的标准名。所有没有这个标志,标准名为空.
如果读者有C的经验,那么肯定知道,通过C语言编写的套接字程序是使用struct sockaddr结构体,它将IP地址表示为二进制,而不是上面显示的Python字符串形式.
如果想在Python和C之间转换IPv4地址,可以使用inet_aton()和inet_ntoa()。示例如下:
import socketimport binasciiip_list = [ "192.168.50.1", "127.0.0.1"]for ip in ip_list: packed = socket.inet_aton(ip) print("原始字符串ip地址:", ip) print("C库能识别的ip地址", binascii.hexlify(packed)) print("还原C库ip地址字符串", socket.inet_ntoa(packed)) print()
运行之后,效果如下:
相信读者如果在测试上面代码,那么输入上面inet_aton()函数时,一定看到提醒中还有inet_pton()与inet_ntop()函数.
这2个函数既能处理IPv4也能处理IPv6,而inet_aton()和inet_ntoa()只能处理IPv4。它们的使用方式如下:
import socketimport binasciiipv6_str = "2001:0db8:3c4d:0015:0000:0000:1a2f:1a2b"packed = socket.inet_pton(socket.AF_INET6, ipv6_str)print("原始字符串ip地址:", ipv6_str)print("C库能识别的ip地址", binascii.hexlify(packed))print("还原C库ip地址字符串", socket.inet_ntop(socket.AF_INET6, packed))print()ipv4_str = "192.168.50.1"packed = socket.inet_pton(socket.AF_INET, ipv4_str)print("原始字符串ip地址:", ipv4_str)print("C库能识别的ip地址", binascii.hexlify(packed))print("还原C库ip地址字符串", socket.inet_ntop(socket.AF_INET, packed))print()
运行之后,效果如下:
以上就是Python实现socket库网络通信套接字的详细内容,更多关于Python socket库的资料请关注我其它相关文章! 。
原文链接:https://blog.csdn.net/liyuanjinglyj/article/details/117389370 。
最后此篇关于Python实现socket库网络通信套接字的文章就讲到这里了,如果你想了解更多关于Python实现socket库网络通信套接字的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。
我目前正在编写的程序有一个小问题。 首先让我解释一下它应该实现什么。 它与聊天程序非常相似,因此从根本上来说,它具有一个信息类(我称它为Packet),该信息类存储有关某些内容的数据,这些数据发生在客
同一角色的多个角色实例是否可以通过从 RoleEnvironment 获取所有这些实例监听的特定端点的 VIP(虚拟 IP)地址来相互通信?如果是这样,则返回的 VIP 可以负载平衡到调用者(Role
概述 ET框架的消息机制贯彻始终,包含Entity消息(Awake,Update ...),自定义(Customer)消息,网络消息等。而ET系统的进程包含了客户端、Gate等各种类型的服务器
我正在尝试设置一个 Docker Swarm,其中容器使用 Overlay Network 进行通信,但我可以让它工作 我正在使用包含 Docker Engine 1.12.1 的 HypriotOS
我是一名优秀的程序员,十分优秀!