파이썬의 SFTP? (플랫폼 독립적)
암호가 하드 코딩 된 하드 코드 된 위치로 파일을 전송하는 간단한 도구를 사용하고 있습니다. 저는 파이썬 초보자이지만 ftplib 덕분에 쉬웠습니다.
import ftplib
info= ('someuser', 'password') #hard-coded
def putfile(file, site, dir, user=(), verbose=True):
"""
upload a file by ftp to a site/directory
login hard-coded, binary transfer
"""
if verbose: print 'Uploading', file
local = open(file, 'rb')
remote = ftplib.FTP(site)
remote.login(*user)
remote.cwd(dir)
remote.storbinary('STOR ' + file, local, 1024)
remote.quit()
local.close()
if verbose: print 'Upload done.'
if __name__ == '__main__':
site = 'somewhere.com' #hard-coded
dir = './uploads/' #hard-coded
import sys, getpass
putfile(sys.argv[1], site, dir, user=info)
문제는 sFTP를 지원하는 라이브러리를 찾을 수 없다는 것입니다. 이와 같은 것을 안전하게 수행하는 일반적인 방법은 무엇입니까?
편집 : 여기에 대한 답변 덕분에 Paramiko와 함께 작동했으며 구문입니다.
import paramiko
host = "THEHOST.com" #hard-coded
port = 22
transport = paramiko.Transport((host, port))
password = "THEPASSWORD" #hard-coded
username = "THEUSERNAME" #hard-coded
transport.connect(username = username, password = password)
sftp = paramiko.SFTPClient.from_transport(transport)
import sys
path = './THETARGETDIRECTORY/' + sys.argv[1] #hard-coded
localpath = sys.argv[1]
sftp.put(localpath, path)
sftp.close()
transport.close()
print 'Upload done.'
다시 감사합니다!
Paramiko 는 SFTP를 지원합니다. 나는 그것을 사용했고, Twisted를 사용했습니다. 둘 다 자리가 있지만 Paramiko로 시작하는 것이 더 쉽다는 것을 알 수 있습니다.
pysftp를 확인해야합니다 https://pypi.python.org/pypi/pysftp paramiko에 의존하지만 가장 일반적인 사용 사례를 몇 줄의 코드로 묶 습니다.
import pysftp
import sys
path = './THETARGETDIRECTORY/' + sys.argv[1] #hard-coded
localpath = sys.argv[1]
host = "THEHOST.com" #hard-coded
password = "THEPASSWORD" #hard-coded
username = "THEUSERNAME" #hard-coded
with pysftp.Connection(host, username=username, password=password) as sftp:
sftp.put(localpath, path)
print 'Upload done.'
쉽고 간단하게 원한다면 Fabric 을 볼 수도 있습니다 . Ruby의 Capistrano와 같은 자동화 된 배포 도구이지만 더 간단하고 물론 Python을위한 도구입니다. Paramiko 위에 빌드되었습니다.
'자동 배포'를 원하지 않을 수도 있지만 Fabric은 사용 사례에 완벽하게 적합합니다. Fabric이 얼마나 간단한 지 보여주기 위해 : 스크립트에 대한 fab 파일과 명령은 다음과 같습니다 (테스트되지 않았지만 99 % 확실하게 작동합니다).
fab_putfile.py:
from fabric.api import *
env.hosts = ['THEHOST.com']
env.user = 'THEUSER'
env.password = 'THEPASSWORD'
def put_file(file):
put(file, './THETARGETDIRECTORY/') # it's copied into the target directory
그런 다음 fab 명령으로 파일을 실행합니다.
fab -f fab_putfile.py put_file:file=./path/to/my/file
그리고 당신은 끝났습니다! :)
다음은 pysftp 및 개인 키를 사용하는 샘플입니다.
import pysftp
def upload_file(file_path):
private_key = "~/.ssh/your-key.pem" # can use password keyword in Connection instead
srv = pysftp.Connection(host="your-host", username="user-name", private_key=private_key)
srv.chdir('/var/web/public_files/media/uploads') # change directory on remote server
srv.put(file_path) # To download a file, replace put with get
srv.close() # Close connection
pysftp는 paramiko 및 pycrypto를 활용하는 사용하기 쉬운 sftp 모듈입니다. sftp에 대한 간단한 인터페이스를 제공합니다. pysftp로 할 수있는 다른 작업은 매우 유용합니다.
data = srv.listdir() # Get the directory and file listing in a list
srv.get(file_path) # Download a file from remote server
srv.execute('pwd') # Execute a command on the server
여기 에 더 많은 명령과 PySFTP에 대한 정보가 있습니다 .
Twisted 는 당신이하는 일에 도움을 줄 수 있고, 그들의 문서를 확인하고, 많은 예제가 있습니다. 또한 큰 개발자 / 사용자 커뮤니티가 뒤에있는 성숙한 제품입니다.
pexpect 모듈을 사용할 수 있습니다.
child = pexpect.spawn ('/usr/bin/sftp ' + user@ftp.site.com )
child.expect ('.* password:')
child.sendline (your_password)
child.expect ('sftp> ')
child.sendline ('dir')
child.expect ('sftp> ')
file_list = child.before
child.sendline ('bye')
나는 이것을 테스트하지 않았지만 작동해야합니다.
Paramiko는 너무 느립니다. 하위 프로세스 및 셸을 사용합니다. 예는 다음과 같습니다.
remote_file_name = "filename"
remotedir = "/remote/dir"
localpath = "/local/file/dir"
ftp_cmd_p = """
#!/bin/sh
lftp -u username,password sftp://ip:port <<EOF
cd {remotedir}
lcd {localpath}
get {filename}
EOF
"""
subprocess.call(ftp_cmd_p.format(remotedir=remotedir,
localpath=localpath,
filename=remote_file_name
),
shell=True, stdout=sys.stdout, stderr=sys.stderr)
단편:
import pysftp
import paramiko
from base64 import decodebytes
keydata = b"""L+WsiL5VL51ecJi3LVjmblkAdUTU+xbmXmUArIU5+8N6ua76jO/+T"""
key = paramiko.RSAKey(data=decodebytes(keydata))
cnopts = pysftp.CnOpts()
cnopts.hostkeys.add(host, 'ssh-rsa', key)
with pysftp.Connection(host=host, username=username, password=password, cnopts=cnopts) as sftp:
with sftp.cd(directory):
sftp.put(file_to_sent_to_ftp)
pysftp에 대해 언급하는 많은 답변이 있으므로 pysftp 주위에 컨텍스트 관리자 래퍼를 원할 경우 다음과 같이 표시되는 코드가 훨씬 적은 솔루션이 있습니다.
path = "sftp://user:p@ssw0rd@test.com/path/to/file.txt"
# Read a file
with open_sftp(path) as f:
s = f.read()
print s
# Write to a file
with open_sftp(path, mode='w') as f:
f.write("Some content.")
(더 완전한) 예 : http://www.prschmid.com/2016/09/simple-opensftp-context-manager-for.html
이 컨텍스트 관리자는 처음 연결할 수없는 경우 자동 재시도 로직이 적용됩니다 (놀랍게도 프로덕션 환경에서 예상하는 것보다 더 자주 발생합니다 ...)
컨텍스트 관리자 요점 open_sftp
: https://gist.github.com/prschmid/80a19c22012e42d4d6e791c1e4eb8515
참고URL : https://stackoverflow.com/questions/432385/sftp-in-python-platform-independent
'Programing' 카테고리의 다른 글
컴파일러가 일반 함수보다 람다를 더 잘 최적화 할 수있는 이유는 무엇입니까? (0) | 2020.05.29 |
---|---|
Java로 LRU 캐시를 어떻게 구현 하시겠습니까? (0) | 2020.05.29 |
LINQ를 사용하여 데이터를 피벗 할 수 있습니까? (0) | 2020.05.29 |
CSV 파일을 SQL Server로 가져 오기 (0) | 2020.05.29 |
외부 Java 클래스가 내부 클래스 전용 멤버에 액세스 할 수있는 이유는 무엇입니까? (0) | 2020.05.29 |