python3中实现客户端与服务端交互发送文件

在python3中实现客户端与服务端程序交互,从客户端发送文件到服务端

客户端代码:client.py

#!/usr/bin/env python
#_*_ encoding=utf-8 _*_

import socket,sys,os

ip_port = (‘127.0.0.1‘,9999)
sk = socket.socket()
sk.connect(ip_port)

container = {‘key‘:‘‘,‘data‘:‘‘}
while True:
    input_data = input(‘path:‘)
    cmd,path = input_data.split(‘|‘)
    file_name = os.path.basename(path)
    file_size = os.stat(path).st_size
    sk.send((cmd+"|"+file_name+"|"+str(file_size)).encode())
    send_size = 0
    f = open(path,‘rb‘)
    Flag = True
    while Flag:
        if send_size + 1024 > file_size:
            data = f.read(file_size - send_size)
            Flag = False
        else:
            data = f.read(1024)
            send_size += 1024
        sk.send(data)
    f.close()
sk.close()

服务端代码server.py

#!/usr/bin/env python
# _*_ encoding=utf-8 _*_

import socketserver,os

class MyServer(socketserver.BaseRequestHandler):
    def handle(self):
        base_path = ‘E:\\\\temp‘
        conn = self.request
        print(‘connected...‘)
        while True:
            pre_data = conn.recv(1024).decode()
            #获取请求方法,文件名,文件大小
            cmd,file_name,file_size = pre_data.split(‘|‘)
            #已经接收文件的大小
            recv_size = 0
            #上传文件路径拼接
            file_dir = os.path.join(base_path,file_name)
            f = open(file_dir,‘wb‘)
            Flag = True
            while Flag:
                #未上传完毕
                if int(file_size)>recv_size:
                    data = conn.recv(1024)
                    recv_size += len(data)
                else:
                    recv_size = 0
                    Flag = False
                    continue
                #写入文件
                f.write(data)
            print(‘upload successed‘)
            f.close()
            
instance = socketserver.ThreadingTCPServer((‘127.0.0.1‘,9999),MyServer)            
instance.serve_forever()

先启动服务端程序,再从命令行中运行client.py

E:\\python\\work\\Pythonlearn1\\src\\test2>python client.py
path:put|E:\\DOWNLOAD\\host.txt
path:put|E:\\DOWNLOAD\\host2.txt
path:Traceback (most recent call last):

如果不取消,客户端会一进提示输入,命令中有一上cmd,可以定义发送或者接收,如果put,get,然后根据这上进行判断做进一步处理

这里有一个问题困扰很久,在python3中,字符串不能直接发送,需要byte,这里使用了encode,接收时再使用decode解码,否则会报错

时间: 2025-01-02 19:14:00

python3中实现客户端与服务端交互发送文件的相关文章

C# TCP实现多个客户端与服务端 数据 与 文件的传输

C#菜鸟做这个东东竟然花了快三天的时间了,真是菜,菜,菜--- 下面是我用C#写的 一个简单的TCP通信,主要的功能有: (1) 多个客户端与服务器间的数据交流 (2)可以实现群发的功能 (3)客户端与服务端可以进行文件的传输 主要用到的知识: TCP里的 socket ... 多线程 Thread ... 下面的是界面: 下面分别是服务端和客户端的代码,如若借用,请标明出处~~~ 服务端代码: [csharp] view plaincopyprint? using System; using 

Android客户端与服务端交互之登陆示例

今天了解了一下android客户端与服务端是怎样交互的,发现其实跟web有点类似吧,然后网上找了大神的登陆示例,是基于IntentService的 1.后台使用简单的servlet,支持GET或POST.这个servlet最终返回给前台一个字符串flag,值是true或false,表示登录是否成功. servlet使用之前需要配置,主义servlet的servlet-name要和servlet-mapping的servlet-name一致,否则找不到路径 我是在myEclipse上创建的一个we

基于socket简易版客户端,服务端交互

简易版客户端服务端交互 常识 AF_UNIX 是基于文件类型的套接字家族 AF_INET是 基础网络类型的套接字家族 socket 模块属性很多,可以直接使用from module import *语句 ,这样socket所有的数据都被带劲命名空间里了. 减少代码量(少用) 服务端 #1导入 import socket # 2.获取套接字 s=socket.socket(socket.AF_INET,socket.SOCK_STREAM) #3绑定 s.bind(('127.0.0.1',807

android客户端与服务端交互的三种方式

android客户端向服务器通信一般有以下选择: 1.传统的java.net.HttpURLConnection类 2.apache的httpClient框架(已纳入android.jar中,可直接使用) 3.github上的开源框架async-http(基于httpClient) ---------------------------------------------------------------------------------- 下面分别记录这三种方式的使用, 传统方式: /**

android 38 Abdroid客户端和服务端交互

服务端: package com.sxt.day05; import java.io.IOException; import java.util.ArrayList; import javax.servlet.ServletException; import javax.servlet.annotation.WebServlet; import javax.servlet.http.HttpServlet; import javax.servlet.http.HttpServletRequest

关于AIDL客户端与服务端交互的包名问题-package

今天在做一个有关AIDL的例子的时候,遇到一个小问题,死活两个进程就是无法通信.按着书上的例子做的(此处代码出自疯狂Android讲义第2版),还是出错,最后在网上查了下才知道是包名的问题.也就是说自己定义的那个AIDL接口所在的包的包名必须保持客户端和服务器端一致.否则会报错,程序强制退出.错误信息如下(事物绑定失败): 在调试模式下会看到如下异常(目标调用异常)抛出: 之所以这样是因为我的包名不一致,如下:                               两者所在的包不一样,这是

超级轻量的远程命令行客户端和服务端(含文件传输)

功能:实现基于TCPIP的命令行操作远程计算机,并且支持远程文件传输 平台:windows   (linux同理) 原理:客户端连接上服务端之后,先监听键盘输入,将键盘输入的cmd指令保存并发送给服务端:服务端保存并通过调用命令行执行,获取命令行执行结果发送给客户端.如果是   获取文件命令,则读取文件,并将文件发送给客户端 代码:源码下载链接 // 核心代码 int getfile(const char *path,SOCKET ClientSocket,const char *file) {

在HTTP通讯过程中,是客户端还是服务端主动断开连接?

比如说:IE访问IIS,获取文件,肯定是要建立一个连接,这个连接在完成通讯后,是客户端Close了连接,还是服务端Close了连接.我用程序测模拟IE和IIS,都没有收到断开连接的消息,也就是都没有触发OnClose事件.我是用Socket建立的连接.如果两方面都没有主动断开连接,那么我猜测可能是传输的数据中有结束的标志,请问这个标志是怎样的?谢谢各位. 解决方案 ? 不知道iis是怎么弄得http的回应包中有个字段通常是close收到指定长度之后就应该断开的. HTTP 你的意思是B/S模式的

项目中客户端,服务端验证,数据库联合唯一约束,事务管理。

项目中有个需求,发布一个活动,记录下参加该活动的id和参与人id,同时调用接口,往收藏夹中添加一条记录,往交易表中添加一条记录.最后根据返回的结果,给出不同的提示信息. 1.如果当前的在jsp页面上面做处理,判断是否参与过.参加过之后,参加按钮不可点.没有参加的情况,参加按钮可以点. 2.jsp客户端加上js处理,参加按钮点击完之后,按钮不可点. 3.在controller中,业务逻辑开始前,再次java判断是否参加过该活动. 4.在数据库中参与表(活动id,参与人id)加上联合唯一约束.根据异