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. html body上有一条空白!!!

    html body 上莫名其妙的就出现了一条空白,怎么搞都搞不定,弄了一下午...... 解决了!!! 格式问题/

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

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

  3. 判断一个字符串是否为GUID的方法

    在.net4.0后出现的TryParse方法可以完成这件事情,至于4.0之前的话,也只能是guid.parse()这个方法加上异常去判断了. 方法具体如下: Guid newGuid = Guid.E ...

  4. Linux运维工程师是什么鬼?

    第一部分:定义 运维工程师,字面理解运行维护. linux运维即linux运维工程师,集合网络.系统.数据库.开发.安全工作于一身的“复合性人才”.   除了传统IT运维部分,运维人员还是管理制度.规 ...

  5. URL Schemes 不能识别和不能跳转的原因

    在app跳转的过程中 需要设置url schemes后,但是设置完后,却不能识别, (测试方式:URL scheme + ://)在浏览器中打开,如果能打开app,就是能跳转 今天遇到了一个坑爹的问题 ...

  6. samba性能调优,调优后,性能增加30%

    global中增加下面内容. [global]    use sendfile = yes    write raw = yes    read raw = yes    max xmit = 655 ...

  7. JS中的async/await的执行顺序详解

    虽然大家知道async/await,但是很多人对这个方法中内部怎么执行的还不是很了解,本文是我看了一遍技术博客理解 JavaScript 的 async/await(如果对async/await不熟悉 ...

  8. js当中mouseover和mouseout多次触发(非冒泡)

    JS当中,mouseover和mouseout多次触发事件,不光是冒泡会产生,就是不冒泡,在一定条件下 ,也会产生多次触发事件: 例如下面的结构的情况下,我在class="ceng_up f ...

  9. C# WinForm 绘制圆角窗体

    public void SetWindowRegion() { System.Drawing.Drawing2D.GraphicsPath FormPath; FormPath = new Syste ...

  10. vue-awesome-swiper实现轮播图

    1.首先通过npm安装vue-awesome-swiper,我在项目中用的是2.6.7版本 npm install vue-awesome-swiper@2.6.7 –save 2. 在main.js ...