python中socket与socketserver模块简单入门使用

简介:

一、socket模块
socket又叫套接字,是网络编程中的一个基本组件,是两个端点的程序之间的“信息通道”程序可分布在不同的计算机上(通过网络连接),通过socket套接字相互发送信息。python中的大多数的网络编程都 隐藏了socket模块的基本细节。
python中通过socket模块完成网络编程的套接字实现,一个套接字就是socket模块中的socket类的一个实例。socket实例化需要三个参数分别是family(ipv4,ipv6,unix)其中默认是ipv4 "socket.AF_INET",第二个参数是流,默认是socket.SOC_STREAM表示tcp,或socket.SOCK_DGRAM,第三个参数是协议,默认是0,使用默认即可。因此实际上实例化出一个套接字,只需要二个参数。

socket通讯原理:
python中socket与socketserver模块简单入门使用

socket函数
python 3.x下发送的内容必须是byte类型,2.x是字符串
python中socket与socketserver模块简单入门使用
python中socket与socketserver模块简单入门使用

二、socket简单通讯
环境说明:ubuntu 16.04 python 3.5.2 模拟的服务器和客户端均在一台机器上(可以在不同机器上,只要保障网络连接)

先来看一个简的服务器与客户端的socket通讯
功能:服务器侦听等待连接,客户端连接后发送连接信息,之后客户端发送的任何信息,服务器端原样返回客户端。
代码如下:
1、srv.py

import socket
sk = socket.socket()
#print(sk)
HOST = '127.0.0.1'
PORT = 2222
BUFSIZ = 1024
ADDR = (HOST,PORT)

sk.bind(ADDR)
sk.listen(5)
print("waiting...")

while True:
    conn,addr = sk.accept()
    ip,port = addr
    print("Got connection from",addr)
    conn.send(bytes("connected from %s:%s." %addr,"utf-8"))
    while True:
        data = conn.recv(BUFSIZ)
        if not data:
            break                                     #直接回车退出本次连接
        print(data)
        conn.send(data)

conn.close()

cli.py

import socket
HOST = '127.0.0.1'
PORT = 2222
BUFSIZ = 1024
ADDR = (HOST,PORT)
sk = socket.socket()
sk.connect(ADDR)
print(sk.recv(BUFSIZ))
while True:
    inp = input(">>>")
        if not inp:                                       #忽略空格回车
            continue
    sk.send(bytes(inp,"utf-8"))
    print(sk.recv(BUFSIZ))

运行结果:
python中socket与socketserver模块简单入门使用
python中socket与socketserver模块简单入门使用

以上是一个最简单的socket网络通讯。以上可以发现双方通讯时一发一收,或一收一发,总是成对出现,但有一个缺点,就是同时只能给一个客户端提供服务(通讯)其他的客户端只能等待。后面通过socketserver来解决一服务器多客户端同时连接的情况。

三、socket上传文件
在完成基本的通讯后,我们来做一个文件上传的实例。
server端

#coding:utf-8
import socket
import os
sk = socket.socket()
#print(sk)
HOST = '127.0.0.1'            #指定ip
PORT = 2222                     #侦听端口
BUFSIZ = 1024                  #缓存大小
ADDR = (HOST,PORT)

sk.bind(ADDR)                   #套接字ip端 口进行绑定
sk.listen(5)                           #连接等待数,默认5
print("waiting....")
BASE_DIR = os.path.dirname(os.path.abspath(__file__))

while True:
    conn, addr = sk.accept()
    print(addr)
    while True:
        data = conn.recv(1024)
        cmd,filename,filesize = (str(data,"utf-8")).split("|")
        path = os.path.join(BASE_DIR,'yuan',filename)
        filesize = int(filesize)

        f = open(path,"ab")
        has_receive = 0
        while has_receive != filesize:
            data = conn.recv(1024)
            f.write(data)
            has_receive+=len(data)
        f.close()

sk.close()

client端

#coding:utf-8
import socket
import os

HOST = '127.0.0.1' 
PORT = 2222
BUFSIZ = 1024
ADDR = (HOST,PORT)
sk = socket.socket()
sk.connect(ADDR)

BASE_DIR = os.path.dirname(os.path.abspath(__file__))
while True:
    inp = input(">>>").strip() #post|12.png
    cmd,path = inp.split("|")
    path = os.path.join(BASE_DIR,path)  ##完整文件路径xxx/12.png
    filename = os.path.basename(path)    ##获取文件名
    file_size = os.stat(path).st_size    #获取文件大小
    file_info = "post|%s|%s" %(filename,file_size)
    sk.sendall(bytes(file_info,"utf-8"))
    f = open(path,'rb')
    has_sent = 0
    while  has_sent != file_size:
        data = f.read(BUFSIZ)
        sk.sendall(data)
        has_sent+=len(data)
    f.close()
    print("上传成功~")
sk.close()

总结:socket通讯的关键是一发一收,无论是服务端先发还是客户端先发,必须是一端发送另一端接收,如果连续发送会出现粘包现象。

四、socketserver实例多并发通讯

server.py

#coding:utf-8
import socketserver    #能实现并发
#并发聊天
class MyServer(socketserver.BaseRequestHandler):
    print("服务端启动...")
    def handle(self):
        while True:
            conn = self.request
            print (self.client_address)
            while True:
                client_data=conn.recv(1024)
                print (str(client_data,"utf8"))
                print ("waiting...")
                server_response=input(">>>")
                conn.sendall(bytes(server_response,"utf8"))
            conn.close()

if __name__ == '__main__':
    server = socketserver.ThreadingTCPServer(('127.0.0.1',2223),MyServer)
    server.serve_forever()

client.py

#coding:utf-8
import socket

ip_port = ('127.0.0.1',2223)
sk = socket.socket()
sk.connect(ip_port)
print ("客户端启动:")
while True:
    inp = input('>>>')
    sk.sendall(bytes(inp,"utf-8"))
    if inp == 'exit':
        break
    server_response=sk.recv(1024)
    print (str(server_response,"utf-8"))
sk.close()

执行结果服务器端通过多线程完成并发多客户端“同时”聊天效果。

以上为socket socketserver基本应用。如有不当之处欢迎指正。










本文转自 dyc2005 51CTO博客,原文链接:http://blog.51cto.com/dyc2005/2044166,如需转载请自行联系原作者
目录
相关文章
|
14天前
|
SQL 关系型数据库 数据库
Python SQLAlchemy模块:从入门到实战的数据库操作指南
免费提供Python+PyCharm编程环境,结合SQLAlchemy ORM框架详解数据库开发。涵盖连接配置、模型定义、CRUD操作、事务控制及Alembic迁移工具,以电商订单系统为例,深入讲解高并发场景下的性能优化与最佳实践,助你高效构建数据驱动应用。
146 7
|
2月前
|
测试技术 开发者 Python
Python单元测试入门:3个核心断言方法,帮你快速定位代码bug
本文介绍Python单元测试基础,详解`unittest`框架中的三大核心断言方法:`assertEqual`验证值相等,`assertTrue`和`assertFalse`判断条件真假。通过实例演示其用法,帮助开发者自动化检测代码逻辑,提升测试效率与可靠性。
235 1
|
28天前
|
监控 安全 程序员
Python日志模块配置:从print到logging的优雅升级指南
从 `print` 到 `logging` 是 Python 开发的必经之路。`print` 调试简单却难维护,日志混乱、无法分级、缺乏上下文;而 `logging` 支持级别控制、多输出、结构化记录,助力项目可维护性升级。本文详解痛点、优势、迁移方案与最佳实践,助你构建专业日志系统,让程序“有记忆”。
158 0
|
18天前
|
JSON 算法 API
Python中的json模块:从基础到进阶的实用指南
本文深入解析Python内置json模块的使用,涵盖序列化与反序列化核心函数、参数配置、中文处理、自定义对象转换及异常处理,并介绍性能优化与第三方库扩展,助你高效实现JSON数据交互。(238字)
191 4
|
1月前
|
Cloud Native 算法 API
Python API接口实战指南:从入门到精通
🌟蒋星熠Jaxonic,技术宇宙的星际旅人。深耕API开发,以Python为舟,探索RESTful、GraphQL等接口奥秘。擅长requests、aiohttp实战,专注性能优化与架构设计,用代码连接万物,谱写极客诗篇。
Python API接口实战指南:从入门到精通
|
29天前
|
存储 Java 调度
Python定时任务实战:APScheduler从入门到精通
APScheduler是Python强大的定时任务框架,通过触发器、执行器、任务存储和调度器四大组件,灵活实现各类周期性任务。支持内存、数据库、Redis等持久化存储,适用于Web集成、数据抓取、邮件发送等场景,解决传统sleep循环的诸多缺陷,助力构建稳定可靠的自动化系统。(238字)
301 1
|
15天前
|
Java 调度 数据库
Python threading模块:多线程编程的实战指南
本文深入讲解Python多线程编程,涵盖threading模块的核心用法:线程创建、生命周期、同步机制(锁、信号量、条件变量)、线程通信(队列)、守护线程与线程池应用。结合实战案例,如多线程下载器,帮助开发者提升程序并发性能,适用于I/O密集型任务处理。
155 0
|
16天前
|
XML JSON 数据处理
超越JSON:Python结构化数据处理模块全解析
本文深入解析Python中12个核心数据处理模块,涵盖csv、pandas、pickle、shelve、struct、configparser、xml、numpy、array、sqlite3和msgpack,覆盖表格处理、序列化、配置管理、科学计算等六大场景,结合真实案例与决策树,助你高效应对各类数据挑战。(238字)
91 0
|
2月前
|
安全 大数据 程序员
Python operator模块的methodcaller:一行代码搞定对象方法调用的黑科技
`operator.methodcaller`是Python中处理对象方法调用的高效工具,替代冗长Lambda,提升代码可读性与性能。适用于数据过滤、排序、转换等场景,支持参数传递与链式调用,是函数式编程的隐藏利器。
93 4

热门文章

最新文章

推荐镜像

更多