Programing

파이썬의 SFTP?

lottogame 2020. 5. 29. 07:52
반응형

파이썬의 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)

RSA 키를 사용하면 여기 를 참조 하십시오.

단편:

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_sftphttps://gist.github.com/prschmid/80a19c22012e42d4d6e791c1e4eb8515

참고URL : https://stackoverflow.com/questions/432385/sftp-in-python-platform-independent


반응형