`
喜欢蓝色的我
  • 浏览: 370833 次
  • 性别: Icon_minigender_2
  • 来自: 北京
社区版块
存档分类
最新评论

python 编写socket

 
阅读更多

python 编写server的步骤: 

  1. 第一步是创建socket对象。调用socket构造函数。如:

    socket = socket.socket( family, type )

    family参数代表地址家族,可为AF_INET或AF_UNIX。AF_INET家族包括Internet地址,AF_UNIX家族用于同一台机器上的进程间通信。
    type参数代表套接字类型,可为SOCK_STREAM(流套接字)和SOCK_DGRAM(数据报套接字)。

  2. 第二步是将socket绑定到指定地址。这是通过socket对象的bind方法来实现的:

    socket.bind( address ) 



    由AF_INET所创建的套接字,address地址必须是一个双元素元组,格式是(host,port)。host代表主机,port代表端口号。如果端口号正在使用、主机名不正确或端口已被保留,bind方法将引发socket.error异常。

  3. 第三步是使用socket套接字的listen方法接收连接请求。

    socket.listen( backlog )

    backlog指定最多允许多少个客户连接到服务器。它的值至少为1。收到连接请求后,这些请求需要排队,如果队列满,就拒绝请求。

  4. 第四步是服务器套接字通过socket的accept方法等待客户请求一个连接。

    connection, address = socket.accept()

    调 用accept方法时,socket会时入“waiting”状态。客户请求连接时,方法建立连接并返回服务器。accept方法返回一个含有两个元素的 元组(connection,address)。第一个元素connection是新的socket对象,服务器必须通过它与客户通信;第二个元素 address是客户的Internet地址。

  5. 第五步是处理阶段,服务器和客户端通过send和recv方法通信(传输 数据)。服务器调用send,并采用字符串形式向客户发送信息。send方法返回已发送的字符个数。服务器使用recv方法从客户接收信息。调用recv 时,服务器必须指定一个整数,它对应于可通过本次方法调用来接收的最大数据量。recv方法在接收数据时会进入“blocked”状态,最后返回一个字符 串,用它表示收到的数据。如果发送的数据量超过了recv所允许的,数据会被截短。多余的数据将缓冲于接收端。以后调用recv时,多余的数据会从缓冲区 删除(以及自上次调用recv以来,客户可能发送的其它任何数据)。
  6. 传输结束,服务器调用socket的close方法关闭连接。

python编写client的步骤: 

  1. 创建一个socket以连接服务器:socket = socket.socket( family, type )
  2. 使用socket的connect方法连接服务器。对于AF_INET家族,连接格式如下:

    socket.connect( (host,port) )

    host代表服务器主机名或IP,port代表服务器进程所绑定的端口号。如连接成功,客户就可通过套接字与服务器通信,如果连接失败,会引发socket.error异常。

  3. 处理阶段,客户和服务器将通过send方法和recv方法通信。
  4. 传输结束,客户通过调用socket的close方法关闭连接。

下面给个简单的例子: 

server.py 

python 代码
import socket
if __name__ == '__main__':
    sock = socket.socket(socket.AF_INET,socket.SOCK_STREAM)
    sock.bind(('0.0.0.0',9001))
    sock.listen(5)
    while True:
        connection,address = sock.accept()
        try:
            connection.settimeout(5)
            buf = connection.recv(1024)
            if buf == '1':
                connection.send('welcome to server!')
            else:
                connection.send('please go out!')
        except socket.timeout:
            print 'time out'
        connection.close()
client.py 
python 代码
import socket
import time
if __name__ == '__main__':
    sock = socket.socket(socket.AF_INET,socket.SOCK_STREAM)
    sock.connect(('0.0.0.0', 9001))
    time.sleep(2)
    sock.send('1')
    print sock.recv(1024)
    sock.close()
在终端运行server.py,然后运行clien.py,会在终端打印“welcome to server!"。如果更改client.py的sock.send('1')为其它值在终端会打印”please go out!“,更改time.sleep(2)为大于5的数值, 服务器将会超时。
下图

上图是一张socket的tcp通信简图,我们都知道tcp的通信需要三次握手。tcp是可靠的、面向连接的、尽力传输的协议,而udp是不可靠 的、面向非连接的、不尽力传输的协议。但是不可靠不代表它没有用,udp有自己的应用场景,语音和视频几乎都在使用udp协议,它的不可靠只是相对于 tcp来说的,但是它的好处就是效率,高效在某些场景要比可靠性重要。这就涉及trade-off了,也就是权衡,需要根据你的应用权衡利弊,然后进行选 择。

在socket选择初始化一个tcp协议的socket之后,就会绑定一个地址和端口,然后开始listen,客户端连接这个listen的tcp 之后,服务端会accept这个请求,然后产生一个新的socket,双方使用这个新的socket(地址和端口,地址还是上面listen的地址,端口 会是一个新的,这个从打印出的结果中可以看出)进行后续的通信。原来的端口会继续的listen新的请求。

转:http://www.centoscn.com/python/2013/0817/1322.html

 
 
 
 
分享到:
评论

相关推荐

    python socket

    Python的socket模块是网络编程的基础,它提供了低级的、原始的TCP/IP和UDP套接字接口。在本文中,我们将深入探讨Python中socket的基本用法、如何创建服务器和客户端,以及涉及的一些重要概念。 首先,理解socket的...

    Python 通过 socket 实现服务端和客户端相互间网络通信的例子

    在Python编程语言中,`socket`模块是进行网络通信的基础工具。它允许程序创建和使用网络连接,使得服务器端和客户端能够交换数据。本例中,我们探讨的是如何使用Python的socket库创建一个简单的服务端(server.py)...

    基于Python的socket网络编程

    本主题将深入探讨“基于Python的socket网络编程”,特别是结合Flask框架来搭建能够传输多种类型数据(如文本、图像、音频等)的网站。 首先,让我们了解基础的socket编程。在Python中,socket模块提供了低级的网络...

    python;Socket接口;测试脚本直接运行

    在这个主题中,我们将深入探讨Python的Socket接口、如何在Windows环境下配置和使用,以及如何编写和运行测试脚本来进行Socket通信。 首先,让我们了解Python中的Socket模块。Python的socket库提供了一种标准的方式...

    python编写的socket测试用例,简单的socket程序

    基于python的程序设计。一个简单的python socket通信程序代码,主要演示socket如何使用

    Python编写的简单的UDP和TCPSocket连接的客户端-服务器程序

    这里我们关注的是使用Python编写的两个基本网络通信模型:TCP(传输控制协议)和UDP(用户数据报协议)的Socket连接。在给定的文件中,包括了TCP服务器(TCPServer.py)、UDP客户端(UDPClient.py)、UDP服务器(UDP...

    daili.zip_PYTHON SOCKET5_python_socket5_zip

    开发者可能通过编写Python脚本来创建一个本地SOCKET5服务器,或者编写一个客户端来连接远程SOCKET5代理。 在标签中,“python_socket5”和“python socket5”强调了这个项目与Python语言以及SOCKET5协议的关联,而...

    python socket 网络编程 教程

    Python网络编程教程主要介绍如何使用Python语言开发基于socket的网络应用程序,通过本教程的学习,初学者可以掌握Python在网络编程方面的基础知识和高级特性。本教程采用的示例为聊天程序,旨在通过实例加深对Python...

    Dos.rar_nine44k_python_python socket_python socket聊天_python聊天室

    本项目" Dos.rar_nine44k_python_python socket_python socket聊天_python聊天室"正是基于Python的socket模块实现的一个多人在线聊天室,让我们来深入探讨这个话题。 首先,我们要理解什么是Python的socket。Socket...

    基于 python 和 socket 的即时通讯文件传输聊天软件【100012564】

    基于 python 和 socket 的即时通讯软件,面向企业,兼具保密性、实用性与趣味性。这个项目基于 python 语言和 PyQt5 框架编写的软件,而且功能丰富,广受好评。- 客户端与服务端须在两个窗口打开(若是在同一个电脑...

    python socket编程实例(服务端及客户端)

    在本实例中,我们将详细探讨如何使用Python的socket库来编写服务端和客户端程序。 首先,让我们从服务端开始。在`server.py`中,我们通常会创建一个socket对象,绑定一个特定的IP地址和端口号,然后监听连接请求。...

    python C socket 编程

    Python以其简洁易读的语法和丰富的库支持在数据处理和脚本编写中大放异彩,而C语言则因其底层控制能力强大,常用于系统编程和嵌入式开发。在网络通信中,Socket编程是一种基础且重要的技术,它允许程序之间通过网络...

    基于Socket的聊天室Python实现(GUI版)

    资源内容:基于Socket的聊天室Python实现(GUI版) 使用/学习目标:了解 Socket 核心原理 特点:简单、带GUI方便使用 适用人群:想阅读Python源码的初学者,想自己搭建远程聊天室的站长们 可以参考本资源来搭建属于...

    Python实现的多人聊天室源码,基于socket tcp通信,使用tkinter做客户端界面,含可执行文件

    在本项目中,我们探讨的是一个使用Python编程语言实现的多人聊天室,它基于socket TCP通信协议,并且利用Tkinter库构建了用户友好的客户端界面。这个聊天室系统允许多个用户同时在线交流,增强了实时互动性。以下是...

    python写的socket聊天室程序,包括客户端和服务端

    在这个场景中,我们有一个基于Python编写的socket聊天室程序,它包含了客户端(client.py)和服务端(server.py)。这个程序允许多个客户端同时连接到服务端,进行双向的信息交流。这里我们将深入探讨涉及的Python...

    python进阶之socket模块详解.pdf

    Python的socket模块是进行网络通信的基础,它提供了一种接口,让程序员能够编写跨平台的TCP/IP协议的应用程序。在Python中,socket模块主要用于实现进程间的网络通信,它基于BSD UNIX的socket API,使得开发者可以...

    python使用socket连接小程序

    11. **异常处理**:在编写socket程序时,需要考虑网络中断、超时等异常情况,通常使用try/except语句进行捕获和处理。 12. **多线程或多进程**:如果服务器需要同时处理多个客户端的连接,可以使用Python的多线程或...

    python聊天室---pyqt5+socket+Thread聊天室

    开发者需要编写事件处理器来响应这些事件,例如,当用户点击发送按钮时,事件处理器将获取文本框中的内容,通过Socket发送到服务器。 6. 数据格式化与编码:在网络通信中,数据通常需要进行特定的格式化(如JSON或...

    pythonsocket

    根据提供的标题、描述以及部分内容,本文将围绕Python中的网络编程技术进行深入探讨,重点解析socket模块及相关的高级网络处理库的使用方法与示例。在Python标准库中,socket是进行网络通信的基础,通过它我们可以...

Global site tag (gtag.js) - Google Analytics