zoukankan      html  css  js  c++  java
  • python之ftp单线程模拟,server端

    __author__ = 'neu'
    import socket
    import os
    import hashlib


    server = socket.socket()          #初始化socket
    server.bind(('localhost',5999))      #绑定地址端口

    server.listen()              #开始监听

    while True:                  #循环等待访问
    conn,addr = server.accept()      #实例化访问用户
    print('new conn:',addr)

    while True:              #对用户输入命令做反复回复
    print('等待新的指令')
    data = conn.recv(1024)      #接收数据大小
    if not data:            #如果为空,断开连接
    print('客户端已断开')      
    break
    cmd,filename = data.decode('utf-8').split()  #以空格为标识符,分解用户发来的信息
    print(filename)
    if os.path.isfile(filename):          #判断是否是文件
    f = open(filename,'rb')          #以二进制打开,避免编码解码
    m = hashlib.md5()              #引入校验码,程序会明显变慢
    file_size = os.stat(filename).st_size  #os模块中stat方法的输出信息是元祖,其中st_size属性是文件大小
    conn.send(str(file_size).encode())    #将整数长度变为字符串并编码发送
    conn.recv(1024)              #接收返回的确认ack
    for line in f:                #开始循环发送数据
    m.update(line)              #更新校验码
    conn.send(line)              #发送数据
    print('file md5',m.hexdigest())
    f.close()
    conn.send(m.hexdigest().encode('utf-8'))  #发送校验码

    print('send done')                  

    server.close()

  • 相关阅读:
    marMariaDB & MYSQL flexviews
    tomcat与resin的比较
    nginx 1.4.3能直接升到1.8.1吗
    Docker Compose vs. Dockerfile
    分布式事务 spring 两阶段提交 tcc
    linux下拷贝整个目录
    MySQL :: Fatal error: Can't change to run as user 'mysql'. Please check that the user exists!
    python Drools
    KubeCon CloudNativeCon China 2019
    在mysql中修改表名的sql语句
  • 原文地址:https://www.cnblogs.com/kcrist/p/9660727.html
Copyright © 2011-2022 走看看