python模块:socket模块

简介:

1.Socket类型

socket(family,type[,protocal])     使用给定的地址族,套接字类型,协议编号(默认是0)来创建套接字                  

socket类型    
描述
socket.AF_UNIX

只能够用于单一的Unix系统进程间通信

socket.AF_INET
服务器之间网络通信
socket.AF_INET6

IPv6

socket.SOCK_STREAM
流式socket , for TCP
socket.SOCK_DGRAM
数据报式socket , for UDP
socket.SOCK_RAW
原始套接字,普通的套接字无法处理ICMPIGMP等网络报文,而SOCK_RAW可以;其次,SOCK_RAW也可以处理特殊的IPv4报文;此外,利用原始套接字,可以通过IP_HDRINCL套接字选项由用户构造IP头.
socket.SOCK_SEQPACKET
可靠的连续数据包服务
创建TCP Socket
s=socket.socket(socket.AF_INET,socket.SOCK_STREAM)
创建UDP Socket
s=socket.socket(socket.AF_INET,socket.SOCK_DGRAM)


2.Socket函数

socket函数(服务器)
描述
s.bind(address)
将套接字绑定到地址AF_INET,以元组(host,port)的形式表示地址.
s.listen(backlog)

开始监听TCP传入连接.backlog指定在拒绝连接之前,操作系统可以挂起的最大连接数量.该值至少为1,大部分应用程序设为5就可以了.

s.accept()
接受TCP连接并返回(conn,address),其中conn是新的套接字对象,可以用来接收和发送数据.address是连接客户端的地址.
socket函数(客户端)
s.connect(address) 连接到address处的套接字.一般address的格式为元组(hostname,port),如果连接出错,返回socket.error错误.
s.connect_ex(adddress)

功能与connect(address)相同,但是成功返回0,失败返回errno的值.

公共socket函数


s.recv(bufsize[,flag])

接受TCP套接字的数据.数据以字符串形式返回,bufsize指定要接收的最大数据量.flag提供有关消息的其他信息,通常可以忽略.

s.send(string[,flag])

发送TCP数据.将string中的数据发送到连接的套接字.返回值是要发送的字节数量,该数量可能小于string的字节大小.

s.sendall(string[,flag])

完整发送TCP数据.将string中的数据发送到连接的套接字,但在返回之前会尝试发送所有数据.成功返回None,失败则抛出异常.

s.close() 关闭套接字.
s.gettimeout()

返回当前超时期的值,单位是秒,如果没有设置超时期,则返回None.

s.fileno() 返回套接字的文件描述符.
s.makefile()

创建一个与该套接字相关连的文件


3.socket原理

TCP服务端:

(1).创建套接字,绑定套接字到本地IP与端口(socket.socket(socket.AF_INET,socket.SOCK_STREAM) , s.bind())

(2).开始监听连接(s.listen())

(3).进入循环,不断接受客户端的连接请求(s.accept())

(4).然后接收传来的数据,并发送给对方数据(s.recv() , s.sendall())

(5).传输完毕后,关闭套接字(s.close())


TCP客户端:

(1).创建套接字,连接远端地址(socket.socket(socket.AF_INET,socket.SOCK_STREAM) , s.connect())

(2).连接后发送数据和接收数据(s.sendall(), s.recv())

(3).传输完毕后,关闭套接字(s.close())


4.例1:简单实现socket通信

服务端:

[root@node1 python]# vim socket12.py 
#!/bin/env python
#!-*- coding:UTF-8 -*-
import socket

s=socket.socket()
host=socket.gethostname()
port=1234
s.bind((host,port))

s.listen(5)
while True:
    c,addr=s.accept()
    print "Got connection from,addr"
    c.send("Thank you for connection")
    c.close()
[root@node1 python]# chmod  755 socket12.py   
[root@node1 python]# ./socket12.py 

[root@node1 python]# netstat -antulp | grep 1234
tcp        0      0   0.0.0.0:1234           0.0.0.0:*                   LISTEN      31580/python    


客户端:

[root@node2 ~]# vim socket12.py 

#!/bin/env python
#!-*- coding:UTF-8 -*-
import socket

s=socket.socket()
host='0.0.0.0'            --服务端的IP地址
port=1234
s.connect((host,port))
print s.recv(1024)

[root@node2 ~]# chmod  755 socket12.py 
[root@node2 ~]# ./socket12.py 
Thank you for connection
[root@node2 ~]# 

此时服务端就会有数据:

wKioL1cYR2uxff34AAAJkT17rUU679.png


5.例2:利用socket协议在客户端操作服务器

服务器端:

[root@node1 python]# cat socket2.py 
#!/bin/env python
#!-*- coding:UTF-8 -*-
import socket
import commands

host=socket.gethostname()     --服务器的主机名
port=1245                                --启动python脚本的端口
s=socket.socket()                      --实例一个socket对像

s.bind((host,port))                     --端口绑定到主机的IP地址
s.listen(5)                                  --允许多少个客户端连接

while True:
    conn,addr=s.accept()           --接收客户端的信息
    print "Connect by",addr       --在服务端输出客户端的IP地址
    while True:
        data=conn.recv(1024)
        cmd_status,cmd_result=commands.getstatusoutput(data)   --获取客户端的命令
        if len(cmd_result.strip()) == 0:
            conn.sendall('Done.')
        else:
            conn.sendall(cmd_result)
conn.close()
[root@node1 python]# ./socket2.py 
[root@node1 python]# netstat -antulp | grep python
tcp        0      0  0.0.0.0:1245           0.0.0.0:*                   LISTEN      2550/python         
[root@node1 python]#


客户端:

[root@node2 ~]# cat socket2.py 
#!/bin/env python
#!-*- coding:UTF-8 -*-
import socket,commands

host='0.0.0.0'         --服务端的IP地址
port=1245
s=socket.socket()
s.connect((host,port))
while True:
    cmd=raw_input("Please input cmd:")
    s.sendall(cmd)
    data=s.recv(1024)
    print data
s.close()
[root@node2 ~]# 
wKioL1cYcpTSwR-nAAAyZ-vprqg099.png










本文转自 z597011036 51CTO博客,原文链接:http://blog.51cto.com/tongcheng/1766143,如需转载请自行联系原作者
目录
相关文章
|
11天前
|
安全 大数据 程序员
Python operator模块的methodcaller:一行代码搞定对象方法调用的黑科技
`operator.methodcaller`是Python中处理对象方法调用的高效工具,替代冗长Lambda,提升代码可读性与性能。适用于数据过滤、排序、转换等场景,支持参数传递与链式调用,是函数式编程的隐藏利器。
52 4
|
2月前
|
存储 安全 数据处理
Python 内置模块 collections 详解
`collections` 是 Python 内置模块,提供多种高效数据类型,如 `namedtuple`、`deque`、`Counter` 等,帮助开发者优化数据处理流程,提升代码可读性与性能,适用于复杂数据结构管理与高效操作场景。
103 0
|
11月前
|
开发者 Python
如何在Python中管理模块和包的依赖关系?
在实际开发中,通常会结合多种方法来管理模块和包的依赖关系,以确保项目的顺利进行和可维护性。同时,要及时更新和解决依赖冲突等问题,以保证代码的稳定性和可靠性
318 62
|
3月前
|
数据安全/隐私保护 Python
抖音私信脚本app,协议私信群发工具,抖音python私信模块
这个实现包含三个主要模块:抖音私信核心功能类、辅助工具类和主程序入口。核心功能包括登录
|
6月前
|
Python
Python教程:os 与 sys 模块详细用法
os 模块用于与操作系统交互,主要涉及夹操作、路径操作和其他操作。例如,`os.rename()` 重命名文件,`os.mkdir()` 创建文件夹,`os.path.abspath()` 获取文件绝对路径等。sys 模块则用于与 Python 解释器交互,常用功能如 `sys.path` 查看模块搜索路径,`sys.platform` 检测操作系统等。这些模块提供了丰富的工具,便于开发中处理系统和文件相关任务。
237 14
|
10月前
|
Python
Python Internet 模块
Python Internet 模块。
210 74
|
7月前
|
人工智能 自然语言处理 Shell
[oeasy]python070_如何导入模块_导入模块的作用_hello_dunder_双下划线
本文介绍了如何在Python中导入模块及其作用,重点讲解了`__hello__`模块的导入与使用。通过`import`命令可以将外部模块引入当前环境,增强代码功能。例如,导入`__hello__`模块后可输出“Hello world!”。此外,还演示了如何使用`help()`和`dir()`函数查询模块信息,并展示了导入多个模块的方法。最后,通过一个实例,介绍了如何利用`jieba`、`WordCloud`和`matplotlib`模块生成词云图。总结来说,模块是封装好的功能部件,能够简化编程任务并提高效率。未来将探讨如何创建自定义模块。
85 8
|
7月前
|
缓存 Shell 开发工具
[oeasy]python071_我可以自己做一个模块吗_自定义模块_引入模块_import_diy
本文介绍了 Python 中模块的导入与自定义模块的创建。首先,我们回忆了模块的概念,即封装好功能的部件,并通过导入 `__hello__` 模块实现了输出 "hello world!" 的功能。接着,尝试创建并编辑自己的模块 `my_file.py`,引入 `time` 模块以获取当前时间,并在其中添加自定义输出。
102 5
|
11月前
|
算法 数据安全/隐私保护 开发者
马特赛特旋转算法:Python的随机模块背后的力量
马特赛特旋转算法是Python `random`模块的核心,由松本真和西村拓士于1997年提出。它基于线性反馈移位寄存器,具有超长周期和高维均匀性,适用于模拟、密码学等领域。Python中通过设置种子值初始化状态数组,经状态更新和输出提取生成随机数,代码简单高效。
269 63
|
11月前
|
Python
Python的模块和包
总之,模块和包是 Python 编程中非常重要的概念,掌握它们可以帮助我们更好地组织和管理代码,提高开发效率和代码质量
219 61

推荐镜像

更多