zoukankan      html  css  js  c++  java
  • Python--------文件的上传

    1.文件的上传

    client

    import socket
    import os
    import json
    import struct
    FILE_PATH = os.path.join(os.path.dirname(__file__), 'demo.mp4')
    def socket_client():
        client = socket.socket()
        client.connect(('127.0.0.1',8848))
        #  1.制作字典形式的报头
        head_dic = {
            'MD5': 123244546656,
            'file_name':os.path.basename(FILE_PATH),
            'file_size': os.path.getsize(FILE_PATH),
            'new_file_name': 'demo1.mp4',
        }
        # 2. 获取json形式的报头
        head_dic_json = json.dumps(head_dic)
        # 3. 获取bytes形式的报头
        head_dic_json_bytes = head_dic_json.encode('utf-8')
        # 4. 获取bytes报头的总字节数
        head_len = len(head_dic_json_bytes)
        # 5. 将bytes报头的总字节数转化成固定4个字节
        four_bytes = struct.pack('i',head_len)
        # 6. 发送固定的4个字节
        client.send(four_bytes)
        # 7.发送报头
        client.send(head_dic_json_bytes)
        # 8. 发送总数据
        '''
        循环条件设定: 
            1. 根据总子节数: file_size: 493701, 每次循环1024个,
            2. 每次取数据不为空,即可.
        '''
        with open(FILE_PATH,mode='rb') as f1:
            while 1:
                every_data = f1.read(1024)
                if every_data:
                    client.send(every_data)
                else:
                    break
        client.close()
    socket_client()
    

    server

    import socket
    import struct
    import json
    import os
    MY_FILE = os.path.join(os.path.dirname(__file__),'my_file')
    def socket_server():
        server = socket.socket()
        server.bind(('127.0.0.1',8848))
        server.listen()
        conn, addr = server.accept()
        # 1. 接收固定长度的4个字节
        four_bytes = conn.recv(4)
        # 2. 利用struct反解
        head_len = struct.unpack('i',four_bytes)[0]
        # 3. 接收bytes类型的报头
        head_dic_json_bytes = conn.recv(head_len)
        # 4. 将bytes类型的报头转化成json
        head_dic_json = head_dic_json_bytes.decode('utf-8')
        # 5. 将json类型报头转化成字典形式的报头
        head_dic = json.loads(head_dic_json)
        # 有一个MD5校验
        # 6. 接收原始数据
        with open(os.path.join(MY_FILE,head_dic['new_file_name']),mode='wb') as f1:
            total_size = 0
            while total_size < head_dic['file_size']:
                every_data = conn.recv(1024)
                f1.write(every_data)
                total_size += len(every_data)
        conn.close()
        server.close()
    socket_server()
    

    2.基于udp协议的socket

    udp协议: 不可靠,相对来说不安全的协议,面向数据报(无连接)的协议,效率高,速度块.

    1563433073454

    client

    import socket
    udp_client = socket.socket(socket.AF_INET,socket.SOCK_DGRAM)  # 基于网络,udp协议的socket
    while 1:
        to_server_data = input('>>>').strip()
        udp_client.sendto(to_server_data.encode('utf-8'),('127.0.0.1', 9000))
        from_server_data = udp_client.recvfrom(1024)
        print(f'来自{from_server_data[1]}的消息:{from_server_data[0].decode("utf-8")}')
    

    server

    import socket
    udp_server = socket.socket(socket.AF_INET,socket.SOCK_DGRAM)  # 基于网络,udp协议的socket
    udp_server.bind(('127.0.0.1', 9000))
    while 1:
        from_client_data = udp_server.recvfrom(1024)
        print(f'来自{from_client_data[1]}的消息:{from_client_data[0].decode("utf-8")}')
        to_client_data = input('>>>').strip()
        udp_server.sendto(to_client_data.encode('utf-8'),from_client_data[1])
    # 还是串行
    
    

    3.socketserver

    虽然可以开启多个client客户端进行聊天,但是从本质上来说,这还是串行.

    server

    import socketserver
    class MyServer(socketserver.BaseRequestHandler): # 继承的类固定的
        def handle(self):  # 必须是这个handle名字.
            while 1:
                from_client_data = self.request.recv(1024).decode('utf-8')  # self.request == conn管道
                print(from_client_data)
                to_client_data = input('>>>').strip()
                self.request.send(to_client_data.encode('utf-8'))
    if __name__ == '__main__':
        ip_port = ('127.0.0.1',8848)
        server = socketserver.ThreadingTCPServer(ip_port,MyServer)
        # server.allow_reuse_address = True
        # print(socketserver.ThreadingTCPServer.mro())
        # [ThreadingTCPServer, ThreadingMixIn,TCPServer, BaseServer]
        server.serve_forever()
        # 1. 入口点:ThreadingTCPServer()
    

    client1

    import socket
    # 1. 创建socket对象(买手机)
    phone = socket.socket() # 可以默认不写
    # 连接服务器ip地址与端口
    phone.connect(('127.0.0.1', 8848))
    # 发消息
    while 1:
        content = input('>>>').strip()
        phone.send(f'怼哥:{content}'.encode('utf-8'))
        # 接收消息
        from_server_data = phone.recv(1024)  # 夯住,等待服务端的数据传过来
        print(f'来自服务端消息:{from_server_data.decode("utf-8")}')
    # 关机
    phone.close()
    

    client2

    import socket
    # 1. 创建socket对象(买手机)
    phone = socket.socket() # 可以默认不写
    # 连接服务器ip地址与端口
    phone.connect(('127.0.0.1', 8848))
    # 发消息
    while 1:
        content = input('>>>').strip()
        phone.send(f'MC骚强:{content}'.encode('utf-8'))
        # 接收消息
        from_server_data = phone.recv(1024)  # 夯住,等待服务端的数据传过来
        print(f'来自服务端消息:{from_server_data.decode("utf-8")}')
    # 关机
    phone.close()
    

    client3

    import socket
    # 1. 创建socket对象(买手机)
    phone = socket.socket() # 可以默认不写
    # 连接服务器ip地址与端口
    phone.connect(('127.0.0.1', 8848))
    # 发消息
    while 1:
        content = input('>>>').strip()
        phone.send(f'安安:{content}'.encode('utf-8'))
        # 接收消息
        from_server_data = phone.recv(1024)  # 夯住,等待服务端的数据传过来
        print(f'来自服务端消息:{from_server_data.decode("utf-8")}')
    # 关机
    phone.close()
    
    
  • 相关阅读:
    当苹果因为UIDevice、udid、uniqueIdentifier而把我们的应用拒之门外invalid binary的时候,呕心沥血解决方法啊
    IOS 7 自定义的UIAlertView不能在iOS7上正常显示
    IOS7 新特性(针对同样讨厌更新后IOS7的开发者)
    CFBundleVersion与CFBundleShortVersionString
    iOS 7 SDK: 如何使用后台获取(Background Fetch)
    IOS开发经验总结(二)
    iOS开发经验总结(一)
    让iOS应用支持不同版本的系统与设备
    控制iOS 7中的状态栏
    Implement CGLIB in ABAP
  • 原文地址:https://www.cnblogs.com/hql1117/p/11209751.html
Copyright © 2011-2022 走看看