--------------------------------------------生活不止眼前的苟且,还有诗和远方的田野.

day 29 socketserver + ftp

# # ------------------------------------------------------------------------------------------------------------#. 
# # --------------[socketserver示例客户端]--------------
import socket
import time
client = socket.socket()
client.connect(('127.0.0.1',8001)) while 1:
client_data = input('别开车>>>')
client.send(client_data.encode('utf-8')) from_server_msg = client.recv(1024)
print(from_server_msg.decode('utf-8')) client.close()
# # --------------[socketserver示例服务端]--------------
import socketserver

class KnightServer(socketserver.BaseRequestHandler):

    def handle(self):
# self.request 相当于conn链接通道
while 1:
from_client_msg = self.request.recv(1024)
print(from_client_msg.decode('utf-8'))
server_msg = input('服务端说>>>')
self.request.send(server_msg.encode('utf-8')) if __name__ == '__main__':
ip_port = ('127.0.0.1',8001)
server = socketserver.ThreadingTCPServer(ip_port,KnightServer)
server.serve_forever()
# # --------------[ftp上传实例客户端]--------------
import socket
import json
import os
import struct
client = socket.socket() client.connect(('127.0.0.1',8001))
file_size = os.path.getsize(r'D:\python_workspace\day029\xxx.mp4')
#定义了一个文件描述信息,以字典的形式
file_info_dict = {
'file_path': r'D:\python_workspace\day029\xxx.mp4',
'file_name': 'xxx.mp4',
'file_size':file_size
} def login(): print('欢迎来到登录页面')
username = input('请输入用户名>')
password = input('请输入密码>')
#将用户名和密码拼接成一个字符串
user_info = username + '|' + password
client.send(user_info.encode('utf-8')) #如果服务端的状态码为200,登录成功,如果不是,登录失败,登录成功,这个信息就是服务端的功能信息
from_server_status = client.recv(1024).decode('utf-8')
if from_server_status == '201':
print('登录失败')
else:
all_file_size = 0
#接收的是一个json格式的字符串
server_func_list = json.loads(from_server_status)
#打印了功能信息
print(server_func_list) #{'1': '上传', '2': '下载'}
client_func_choice = input('请输入要选择的功能序号>>>')
#选择1,说明要上传
if client_func_choice == '1':
# 上传或者下载的功能序号添加到了文件描述信息的字典中
file_info_dict['func_choice'] = client_func_choice
file_dict_json = json.dumps(file_info_dict,ensure_ascii=False)
#发送文件描述信息
client.send(file_dict_json.encode('utf-8'))
#
with open(file_info_dict['file_path'],'rb') as f:
while all_file_size < file_info_dict['file_size']:
every_read_data = f.read(1024)
client.send(every_read_data)
every_read_datalen = len(every_read_data) all_file_size += every_read_datalen def register():
print('注册') print('-----请登录------')
print('1:登录\n2:注册') #选择登录
function_choice = input('请输入你要选择的功能序号>>>>')
#通过选择的序号,找到对应的函数执行,一个字典搞定
function_dict = {'1':login,'2':register} function_dict[function_choice]()
# # --------------[ftp上传实例服务端]--------------
import socket
import time
import json
server = socket.socket() server.bind(('127.0.0.1',8001))
server.listen() conn,addr = server.accept() def upload(conn,client_file_info):
#
upload_file_path = r'D:\jj' + '\\' + client_file_info['file_name']
recv_all_datalen = 0
with open(upload_file_path,'wb') as f:
while recv_all_datalen < client_file_info['file_size']:
every_recv_data = conn.recv(1024)
every_recv_datalen = len(every_recv_data)
recv_all_datalen += every_recv_datalen
f.write(every_recv_data) print('客户端上传文件') client_userinfo = conn.recv(1024).decode('utf-8')
#定义一个需要返回给服务端的功能列表
server_function_list = {'1':'上传','2':'下载'}
#将功能字典转换为json字符串,然后进行编码,转成bytes类型
json_func_list = json.dumps(server_function_list,ensure_ascii=False) #服务端登录认证
with open('userinformation','r',encoding='utf-8') as f:
for i in f:
if i.strip() == client_userinfo:
#登录成功以后,将服务端能够提供的功能,发送给客户端
conn.send(json_func_list.encode('utf-8'))
#接收客户端的文件描述信息,其中有一项是功能序号
client_fileinfo_json = conn.recv(1024).decode('utf-8')
client_file_info = json.loads(client_fileinfo_json) print(client_file_info)
if client_file_info['func_choice'] == '1':
upload(conn,client_file_info) break
else:
#登录错误的信息码
conn.send(b'201')

												

socketserver + ftp的更多相关文章

  1. Python socketserver ftp功能简单讲解

    socketserver模块实现并发 为什么要讲socketserver?我们之前写的tcp协议的socket是不是一次只能和一个客户端通信,如果用socketserver可以实现和多个客户端通信.它 ...

  2. python socketserver ftp上传功能

    一.socketserver用于多个客户端访问同一个服务端 客户端 import socket client = socket.socket() ip_port = ('127.0.0.1',8001 ...

  3. python之socketserver ftp功能简单讲解

    TCP协议中的socket一次只能和一个客户端通信,然而socketserver可以实现和多个客户端通信. 它是在socket的基础上进行了一层封装,底层还是调用的socket # 服务端 impor ...

  4. day 29 socketserver ftp功能的简单讲解

    1.上传下载的简单示例 server: import socket import struct import json   server =socket.socket() server.bind((' ...

  5. 29 Socketserver和 ftp

    一.Socketserver #服务端 import socketserver class KnightServer(socketserver.BaseRequestHandler): def han ...

  6. Day30--Python--struct, socketserver

    1. struct struct.pack 打包 def pack(fmt, *args): # known case of _struct.pack """ pack( ...

  7. Python全栈--目录导航

    这里更新以Python语言作为基础,想要成为全栈工程师需要掌握的技能... Python基础语法 day01 初识Python day02 while循环 运算符和编码 day03 字符串 day04 ...

  8. 开发socketserver 以及定制开发自己的FTP服务器

    socket server 示例 #服务端程序 import socketserver class TcpHandler(socketserver.BaseRequestHandler): def h ...

  9. socketserver模块写的一个简单ftp程序

    一坨需求... 用户加密认证 允许同时多用户登录 每个用户有自己的家目录 ,且只能访问自己的家目录 对用户进行磁盘配额,每个用户的可用空间不同 允许用户在ftp server上随意切换目录 (cd) ...

随机推荐

  1. JHipster生成微服务架构的应用栈(三)- 业务微服务示例

    本系列文章演示如何用JHipster生成一个微服务架构风格的应用栈. 环境需求:安装好JHipster开发环境的CentOS 7.4(参考这里) 应用栈名称:appstack 认证微服务: uaa 业 ...

  2. ES搜索引擎集群模式搭建【Kibana可视化】

    一.简介 ElasticSearch是一个基于Lucene的搜索服务器.它提供了一个分布式多用户能力的全文搜索引擎(与Solr类似),基于RESTful web接口.Elasticsearch是用Ja ...

  3. 在安卓手机上通过虚拟机运行Windows XP

    转自:https://www.ithome.com/html/android/302170.htm 细数当年的桌面版Windows,似乎针对ARM架构处理器的版本并不多,小编曾用过一段时间的Windo ...

  4. C# -- 交错数组的使用

    C# -- 交错数组的使用 交错数组是元素为数组的数组.交错数组元素的维度和大小可以不同.交错数组有时称为“数组的数组”. 1. 举例一:子数组是长度相同的一维数组 static void Main( ...

  5. C语言 实现逆置功能

    C语言 实现逆置功能 //凯鲁嘎吉 - 博客园 http://www.cnblogs.com/kailugaji/ 1. 字符串的逆置 方法1:利用数组 #include<stdio.h> ...

  6. MVC+EF 序列化类型为“System.Data.Entity.DynamicProxies.__的对象时检测到循环引用

    用MVC+EF做简单查询时,返回json格式数据出现问题 原代码: public ActionResult JSon({ NorthwindEntities db = new NorthwindEnt ...

  7. SpringBoot2.0 最简单的 idea 快速创建项目

    第一步 第二步 第三步 以上就是idea快速创建springboot的方法,创建之后等maven 依赖下载完成,就可以使用

  8. Nginx+Keepalived双机热备

    一.Keepalived Keepalived是保证集群高可用的服务软件.网络中优先级高的节点为master负责响应VIP的ARP包,将VIP和MAC地址映射关系告诉网络内其他主机,还会以多播的形式向 ...

  9. centos7下安装docker(15.7容器跨主机网络---calico)

    Calico是一个纯三层的虚拟网络方案,Calico为每个容器分配一个IP,每个host都是router,把不同host的容器连接起来.与vxlan不同的是:calico不对数据包进行封装,不需要NA ...

  10. eclipse导入maven项目, A resource exists with a different case: '/xxx'.

    eclipse 导入maven 项目出现 这是由于你的workspace里有相同的项目, 这时在metadata里可以看到所有的project信息 只需在eclipse的package explore ...