ftp客服端实现自动更新文件(带自动启动功能并封装为带配置文件的工具)-python
前言
由于工位机不可能做到实时看守,当更新程序的时候我们还得手动去工位机上安装程序并运行,实属麻烦,因此笔者就研究了一下ftp自动更新并启动程序,最后封装为带一个配置文件的exe,所有人都可以使用的工具。
功能:通过配置文件从ftp服务端更新某个指定文件夹里的所有文件和目录(已经有了的不会下载,只下载更新的),可指定是否启动更新后自启动程序(启动的程序可自定义)功能,
一、项目环境和结构
环境
- python3.7_32位 (anaconda实现)
- 本地模拟ftp服务端(下一篇文章介绍服务器上部署公网ftp服务端)
# -*- coding:utf-8 -*-
from pyftpdlib.authorizers import DummyAuthorizer
from pyftpdlib.handlers import FTPHandler
from pyftpdlib.servers import FTPServer
# 实例化DummyAuthorizer来创建ftp用户
authorizer = DummyAuthorizer()
# 参数:用户名,密码,目录,权限
authorizer.add_user('admin', '12345', r'E:\project_code\ftp\ftpmyserver\File', perm='elradfmwMT')
# E:\project_code\ftp\ftpmyserver\File
# 匿名登录
# authorizer.add_anonymous('/home/nobody')
handler = FTPHandler
handler.authorizer = authorizer
# #添加被动端口范围
# handler.passive_ports = range(21212, 21213)
# 参数:IP,端口,handler
server = FTPServer(('0.0.0.0', 21), handler) #设置为0.0.0.0为本机的IP地址
server.serve_forever()
-
结构
- administrator.py(以管理员身份执行某端代码封装,它是为了我后续自动启动电脑里某个文件的程序时候以管理员去运行,没有这块需求可以去掉,)
- ftpclient.py
- configuration.txt (配置文件)
代码
- configuration.txt
HOST = 127.0.0.1 #远程ftp服务器的ip地址
FTPDir = / #需要下载的ftp服务端目录路径
LocalDir = E:\project_code\ftp\ftpclient\down # 本地存贮路径
flag = True #是否需要打开更新后自动启动程序功能
dir = E:\project_code\companyId\dist\start_service.bat #需要自启动的文件路径
- administrator.py
# coding:utf8
# -*- coding: utf-8 -*-
"""
Created on
@author: tql
Function:以管理员身份执行代码块
"""
from __future__ import print_function
import os
import sys
import ctypes
import inspect
if sys.version_info[0] == 3:
import winreg as winreg
else:
import _winreg as winreg
CMD = r"C:\Windows\System32\cmd.exe"
FOD_HELPER = r'C:\Windows\System32\fodhelper.exe'
PYTHON_CMD = "python"
REG_PATH = 'Software\Classes\ms-settings\shell\open\command'
DELEGATE_EXEC_REG_KEY = 'DelegateExecute'
def is_admin():
'''
Checks if the script is running with administrative privileges.
Returns True if is running as admin, False otherwise.
'''
try:
return ctypes.windll.shell32.IsUserAnAdmin()
except:
return False
def create_reg_key(key, value):
'''
Creates a reg key
'''
try:
winreg.CreateKey(winreg.HKEY_CURRENT_USER, REG_PATH)
registry_key = winreg.OpenKey(winreg.HKEY_CURRENT_USER, REG_PATH, 0, winreg.KEY_WRITE)
winreg.SetValueEx(registry_key, key, 0, winreg.REG_SZ, value)
winreg.CloseKey(registry_key)
except WindowsError:
raise
def bypass_uac(cmd):
'''
Tries to bypass the UAC
'''
try:
create_reg_key(DELEGATE_EXEC_REG_KEY, '')
create_reg_key(None, cmd)
except WindowsError:
raise
def execute():
if not is_admin():
print('[!] The script is NOT running with administrative privileges')
print('[+] Trying to bypass the UAC')
try:
current_dir = __file__
cmd = '{} /k {} {}'.format(CMD, PYTHON_CMD