import socket
import os
import time
import pickle
Basedb = os.path.dirname(os.path.dirname(os.path.abspath(__file__)))
class client_ftp(object):
#客户端类
def __init__(self,add,port):
#客户端属性,地址和端口
self.add = add
self.port = port
#注册用户
def register(self):
username = input('请输入用户名:').strip()
password = input('请输入密码:').strip()
if not username or not password:
print('输入为空!')
elif username in os.listdir('%s/db'%Basedb):
print('用户已存在!')
else:
save = {'username':username,'password':password}
db_path = Basedb + '/db/' + username
#存入用户信息
pickle.dump(save,open(db_path,'wb'))
#生成用户文件夹
os.mkdir(Basedb + '/client_file/' + username)
print('注册成功!') def login_in(self):
#登陆验证方法
username = input('请输入用户名:').strip()
password = input('请输入密码:').strip()
if username in os.listdir('%s/db'%Basedb):
db_path = Basedb + '/db/' + username
db_dict = pickle.load(open(db_path,'rb'))
if password == db_dict['password']:
print('登陆成功!')
flag = True
else:
print('密码错误!')
flag = False
else:
print('用户名错误!')
flag = False
return flag
def conn_server(self):
#连接方法
client = socket.socket()
client.connect((self.add,self.port))
code_in = input('请输入用户名:').strip()
client.send(code_in.encode('UTF-8'))
data = client.recv(1024000).decode()
print(data)
#如果返回成功
if data == 'success':
server_file = os.listdir(Basedb + '/client_file/' + code_in)
send_file = os.listdir(Basedb + '/send')
while 1:
option = input('''
-----option-----
1.输入1获取文件目录;
2.直接输入文件名称下载文件
3.将文件拖至send文件夹中,并输入文件名,上传到服务器
4.退出
''').strip()
if option == '':
client.send('check'.encode('utf-8'))
print(client.recv(1024000).decode())
elif option in server_file:
client.send(option.encode('utf-8'))
data1 = client.recv(1024000).decode()
file_name = Basedb + '/send'
time_now =time.strftime("%Y-%m-%d-%H-%M-%S",time.localtime(time.time()))
with open('%s/%s'%(file_name,time_now),'w') as f:
f.write(data1)
print('接收成功!')
elif option in send_file:
client.send('load'.encode('utf-8'))
print(client.recv(1024000).decode())
f_open = open('%s/send/%s'%(Basedb,option),'r')
back_data = f_open.read()
client.send(str(back_data).encode('utf-8'))
f_open.close()
print('传输成功!')
else:
exit() if __name__ == '__main__':
client_start = client_ftp('localhost',6969)
while 1:
option = input('''
--------option--------
1.注册
2.登陆
3.退出
''').strip()
if option == '':
client_start.register()
elif option =='':
flag = client_start.login_in()
if flag== True :
client_start.conn_server()
else:
print('登陆失败了哥们')
break
else:
exit()
import socket
import os
import time
Base_path = os.path.dirname(os.path.dirname(os.path.abspath(__file__)))
class Server_ftp(object):
#此类为ftp服务端
def __init__(self,add,port):
self.add = add
self.port = port
def conn_listen(self):
server = socket.socket()
server.bind((self.add,self.port))
server.listen(5)
print('监听正在进行!监听地址为:',self.add,'监听端口为:',self.port)
while 1:
conn,addr = server.accept()
print('已建立连接!')
data = conn.recv(1024000).decode()
print("recv:", data)
if not data:
print("client has lost...")
break
elif os.path.exists(Base_path + '/client_file/' + data):
allfile = os.listdir(Base_path + '/client_file/' + data)
conn.send('success'.encode('utf-8'))
while 1:
data1 = conn.recv(1024000).decode()
if not data1:
print("client has lost...")
break
elif data1 == 'check':
conn.send(str(allfile).encode('utf-8'))
break
elif data1 in allfile:
file_name = Base_path + '/client_file/' + data
f_open = open('%s/%s'%(file_name,data1),'rb')
back_data = f_open.read()
conn.send(str(back_data).encode('utf-8'))
f_open.close()
break
elif data1 == 'load':
conn.send('reading'.encode('utf-8'))
data2 = conn.recv(1024000).decode()
if not data2:
print("client has lost...")
break
else:
file_name = Base_path + '/client_file/' + data
time_now =time.strftime("%Y-%m-%d-%H-%M-%S",time.localtime(time.time()))
with open('%s/%s'%(file_name,time_now),'w') as f:
f.write(data2)
print('接收成功!')
conn.send('接收成功!'.encode('utf-8'))
break
else:
print('data1输入错误!')
conn.send('data1输入错误!'.encode('utf-8'))
else:
print('接收错误!')
conn.send('错误输入!'.encode('utf-8'))
break if __name__ == '__main__':
sever_start = Server_ftp('localhost',6969)
sever_start.conn_listen()

python 学习分享-实战篇简单的ftp的更多相关文章

  1. python 学习分享-实战篇高级的ftp

    #server代码 import socketserver,os,hashlib Base_paht = os.path.dirname(os.path.dirname(os.path.abspath ...

  2. python 学习分享-实战篇选课系统

    # 角色:学校.学员.课程.讲师 # 要求: # 1. 创建北京.上海 2 所学校 # 2. 创建linux , python , go 3个课程 , linux\py 在北京开, go 在上海开 # ...

  3. python 学习分享-实战篇增删改查作业

    一大波函数来袭 作业要求: 1本次作业通过空格及逗号,将文件拆分成列表,在通过判断add.del.update.select等关键字,来判断用户执行的是哪种命令,根据不同的命令调用不同的函数去处理. ...

  4. python 学习分享-实战篇类 Fabric 主机管理程序开发

    # 类 Fabric 主机管理程序开发: # 1. 运行程序列出主机组或者主机列表 # 2. 选择指定主机或主机组 # 3. 选择让主机或者主机组执行命令或者向其传输文件(上传/下载) # 4. 充分 ...

  5. python 学习分享-函数篇

    函数是组织好的,可重复使用的,用来实现单一,或相关联功能的代码段. 函数能提高应用的模块性,和代码的重复利用率.你已经知道Python提供了许多内建函数,比如print().但你也可以自己创建函数,这 ...

  6. python 学习分享-字典篇

    python字典(Dictionary) dict是无序的 key必须是唯一切不可变的 a={'key1':'value1','key2':'value2'} 字典的增删改查 a['key3']='v ...

  7. python 学习分享-基础篇

    1.python起手式 写下第一个代码,打印‘hello world’ print('hello world') 2.变量 变量是为了存储信息,在程序中被调用,标识数据名称或类型. 变量定义的规则: ...

  8. python 学习分享-函数篇2

    递归 自己玩自己的函数: 1. 必须有一个明确的结束条件 2. 每次进入更深一层递归时,问题规模相比上次递归都应有所减少 3. 递归效率不高,递归层次过多会导致栈溢出 递归例子和二分查找都放在里面了 ...

  9. Python学习笔记基础篇——总览

    Python初识与简介[开篇] Python学习笔记——基础篇[第一周]——变量与赋值.用户交互.条件判断.循环控制.数据类型.文本操作 Python学习笔记——基础篇[第二周]——解释器.字符串.列 ...

随机推荐

  1. 559. N 叉树的最大深度

    给定一个 N 叉树,找到其最大深度. 最大深度是指从根节点到最远叶子节点的最长路径上的节点总数. 例如,给定一个 3叉树 : 我们应返回其最大深度,3. 说明: 树的深度不会超过 1000.树的节点总 ...

  2. 根据accept-language自动设置UICulture和Culture

    在web.config中添加如下配置: <system.web> <globalization uiCulture="auto" culture="au ...

  3. 302和VS启动后网站拒绝访问的解决方案

    网页状态302代表的是重定向的意思,就是网页跳转的一种状态 网站拒绝访问的时候可以在输出窗口查看是否有内容输出,如果没有说明启动网站的端口可能被占用,在网站项目——属性——web——项目中把地址的端口 ...

  4. 前端三大框架 Vue.js、AngularJS、React 的区别

    Vue.js Vue.js 是一种构建数据驱动的Web界面的渐进式框架,Vue.js 采用自底向上增量开发的设计. Vue.js 轻量高效,数据双向绑定(响应式数据绑定), 它会自动响应数据的变化情况 ...

  5. 题解 CF734A 【Anton and Danik】

    本蒟蒻闲来无事刷刷水题 话说这道题,看楼下的大佬们基本都是用字符 ( char ) 来做的,那么我来介绍一下C++的优势: string ! string,也就是类型串,是C语言没有的,使用十分方便 ...

  6. JDBC中 mysql数据库的连接工具类 Java登录 及增删改查 整理 附带:Navicat Premium 11.0.12中文破解版.zip(下载)mysql数据库工具

    先写一个工具类,有实现MySQL数据库连接的方法,和关闭数据库连接.关闭ResultSet  结果集.关闭PreparedStatement 的方法.代码如下: package com.swift; ...

  7. rem适配方案

    页面布局单位计算 一般有两大类:绝对长度单位和相对长度单位 绝对长度单位: px 像素:是显示屏上显示的每一个小点,为显示的最小单位 in 英寸,1in = 96px cm 厘米,1cm = 37.8 ...

  8. Uva 填充正方形

    暴力出奇迹 #include<iostream> #include<cstdio> using namespace std; +; int T,n; char S[maxn][ ...

  9. SpingBoot之多Profile文件

    1.我们在主配置文件编写的时候,文件名可以是 application-{profile}.properties/yml默认使用application.properties的配置: 在我们的项目开发.测 ...

  10. SpringBoot之HelloWorld仔细分析

    程序中的pom.xml文件: 一.父级标签 <parent> <groupId>org.springframework.boot</groupId> <art ...