Как клиент может получить на сервер загруженный оригинальный файл с именем файла и расширением? - PullRequest
0 голосов
/ 26 декабря 2018

Пожалуйста, помогите мне, я только начинающий Python, и я хочу научиться этому.Я понятия не имею, как получить исходное имя файла и расширение от серверной части.

Я пробую много способов и исследований, но все еще не могу это сделать.Я видел много типов примеров, которые просто могут загружать только текстовый файл с with open('received_file','.txt','wb') as f: в клиентской части и не могут загружать несколько типов расширений файлов.Я знаю из-за '.txt', поэтому просто работайте для текстового файла.Я не, как объявить, чтобы получить несколько расширений и оригинальное имя файла.Это мой оригинальный код.

client


import socket
import os
TCP_IP = 'localhost'
TCP_PORT = 9001
BUFFER_SIZE = 8192

s = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
s.connect((TCP_IP, TCP_PORT))
#data = s.recv(BUFFER_SIZE)


with open('received_file','.txt','wb') as f:
    print ('file opened')
    while True:
        print('receiving data...')
        data = s.recv(BUFFER_SIZE)
        print('data=%s', (data))
        if not data:
            f.close()
            print ('file close()')
            break
        # write data to a file
        f.write(data)

print('Successfully get the file')
s.close()
print('connection closed')

Цитата

server


import socket
from threading import Thread
from socketserver import ThreadingMixIn
import tkinter
import tkinter.filedialog

TCP_IP = 'localhost'
TCP_PORT = 9001
BUFFER_SIZE = 8192
tkinter.Tk().withdraw() 
in_path = tkinter.filedialog.askopenfilename( )
class ClientThread(Thread):

    def __init__(self,ip,port,sock):
        Thread.__init__(self)
        self.ip = ip
        self.port = port
        self.sock = sock
        print (" New thread started for "+ip+":"+str(port))

    def run(self):
        filename= in_path
        f = open(filename,'rb')
        while True:
            l = f.read(BUFFER_SIZE)
            while (l):
                self.sock.send(l)
                l = f.read(BUFFER_SIZE)
            if not l:
                f.close()
                self.sock.close()
                break

tcpsock = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
tcpsock.setsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR, 1)
tcpsock.bind((TCP_IP, TCP_PORT))
threads = []

while True:
    tcpsock.listen(5)
    print ("Waiting for incoming connections...")
    (conn, (ip,port)) = tcpsock.accept()
    print ('Got connection from ', (ip,port))
    newthread = ClientThread(ip,port,conn)
    newthread.start()
    threads.append(newthread)

for t in threads:
    t.join()

Выходной файл с именем receive_file без расширения.

1 Ответ

0 голосов
/ 26 декабря 2018

Вам необходимо определить протокол, который передает имя файла, а затем данные.Вот пример, который передает содержимое input.txt клиенту как имя файла output.txt.Клиент читает имя файла, а затем записывает данные в это имя файла.Я сделал это просто потому, что клиент и сервер работали на одном компьютере и считывали и записывали файлы в одном каталоге.

server.py

import socketserver

class MyTCPHandler(socketserver.BaseRequestHandler):
    def handle(self):
        filename = 'output.txt'
        self.request.sendall(filename.encode() + b'\r\n')
        with open('input.txt','rb') as f:
            self.request.sendall(f.read())

if __name__ == "__main__":
    HOST, PORT = "localhost", 9001
    with socketserver.ThreadingTCPServer((HOST, PORT), MyTCPHandler) as server:
        server.serve_forever()

client.py

import socket
import os
SERVER = 'localhost',9001

s = socket.socket()
s.connect(SERVER)

# autoclose f and s when with block is exited.
# makefile treats the socket as a file stream.
# Open in binary mode so the bytes of the file are received as is.
with s,s.makefile('rb') as f:
    # The first line is the UTF-8-encoded filename.  Strip the line delimiters.
    filename = f.readline().rstrip(b'\r\n').decode()
    with open(filename,'wb') as out:
        out.write(f.read())
...