• Python网络编程之TCP套接字简单用法示例


    Python网络编程之TCP套接字简单用法示例

    本文实例讲述了Python网络编程之TCP套接字简单用法。分享给大家供大家参考,具体如下:
    上学期学的计算机网络,因为之前还未学习python,而java则一知半解,C写起来又麻烦,所以一直都没有真正实现过TCP套接字编程。
    最近学习了python,而用它来写套接字又十分方便简单,所以当然要试一试咯。

    下面根据代码来介绍一下最简单的tcp程序,由客户端输入数据,发送给服务器,服务器加上时间后返回给客户端    
    #!/usr/bin/python
    'test TCP server'
    from socket import *  #套接字所需要的模块
    from time import ctime  #时间模块
    HOST = ''  #主机名,为空,表示可以绑定在任何有效的地址上。
    PORT = 21567  #随机选的可用端口
    BUFSIZ = 1024  #发送数据的缓冲区
    ADDR = (HOST, PORT)
    tcpSerSock = socket(AF_INET, SOCK_STREAM)  #第一个参数是socket_family,此处用常用的AF_INET,第二个参数是流套接字,即创建的是tcp
    tcpSerSock.bind(ADDR)  #套接字与地址绑定
    tcpSerSock.listen(5)  #开始监听,参数表示允许的最大连接数
    while True:
      print 'waiting for connection...'
      tcpCliSock, addr = tcpSerSock.accept()  #打开大门等待客人,accept返回一个元组(connection,address)。第一个元素是新的socket对象,服务器必须通过它与客户通信;第二个是客户的地址。
      print '...connected from:',addr
      while True:
        data = tcpCliSock.recv(BUFSIZ)  #洗耳恭听,把客人的话记录到data中
        if not data:  #客人话说完了,送客
          break
        tcpCliSock.send('[%s] %s' %(ctime(), data))  #发送当前时间,以及数据给客人
      tcpCliSock.close()  #送客,关闭与该客人通信的套接字
    tcpSerSock.close()  #因为上面是死循环,此处不是必须的,只是提醒大家离开的时候务必要关门!

    上面用到了两个套接字,第一个tcpSerSock称为欢迎套接字,第二个tcpCliSock才是真正负责与客户端通信的套接字,这样做的好处是,一个服务器可以同时接待多个客人。

    下面则是客户端的代码,非常简单:    
    #!/usr/bin/python
    'test tcp client'
    from socket import *
    HOST = 'localhost'  #因为我是在同一台机器上运行,所以是localhost,不同主机的话,此处需要改成服务器地址
    PORT = 21567
    BUFSIZ = 1024
    ADDR = (HOST, PORT)
    tcpCliSock = socket(AF_INET, SOCK_STREAM)  #客户端只需要一个套接字
    tcpCliSock.connect(ADDR)  #发起连接
    while True:
      data = raw_input('>')
      tcpCliSock.send(data)  #发送数据
      if not data:
        break
      data = tcpCliSock.recv(BUFSIZ)  #接收数据
      print data
    tcpCliSock.close()

  • 相关阅读:
    014_IP专项研究监控
    023_System Integrity Protection in macos
    013_UDP专项研究监控
    谈谈MySQL的do语句
    MySQL8的新特性CTE
    MySQL通过Explain查看select语句的执行计划结果触发写操作
    关于QueryCache的一次打脸
    Python 实现进程间通信(网络编程)
    MySQL自成一派的查询提示
    谈谈MySQL的WriteSet并行复制
  • 原文地址:https://www.cnblogs.com/amengduo/p/9586313.html
Copyright © 2020-2023  润新知