[英]Paramiko Python: IOError: [Errno 13] Permission denied
問題:
我可以做這樣的事情:
self.sftp.put(sourceFilePath, final_destination, use_sudo=True)
我可以創建文件夾,但不能創建文件? 我是否需要明確調用 sudo 或在 paramiko 中設置一些東西? 我應該將文件復制到允許的空間並進行 chowning 嗎? 有沒有辦法讓 paramikko sudoer 不使用密鑰或不必弄亂ssh.exec_command("sudo mv")
? 我錯過了什么?
編碼:
class Ssh(object):
def __init__(self):
super(Ssh, self).__init__()
def setup(self):
'''Setup connection'''
try:
# DEBUG
paramiko.common.logging.basicConfig(level=paramiko.common.DEBUG)
#set username & password
username = 'sgdevbox'
password = MainFrame.ssh_pass
host = '192.168.0.170'
port = 22
self.transport = paramiko.Transport((host, port))
self.transport.connect(username = username, password = password)
self.sftp = paramiko.SFTPClient.from_transport(self.transport)
print(self.sftp.sock)
except Exception, e:
print(traceback.format_exc())
def putFiles(self, sources, listingSku):
'''
Upload images to server along with all currentItemInfo, plus initials and date
Basically build the auction and put it into the queue for verification
'''
print('\n# Ssh.putFiles() #')
if isinstance(sources, unicode):
sources = {sources,'True'}
try:
self.setup()
destination = '/var/www'
cwd = os.getcwd()
for source in sources:
filename = os.path.split(source)[-1]
destinationFolder = listingSku
final_path = posixpath.join(destination,destinationFolder)
try:
self.sftp.mkdir(final_path, mode=777)
except:
print(traceback.format_exc())
final_destination = posixpath.join(final_path, filename)
sourceFilePath = os.path.join(cwd,source)
print('\n# Source Path: {}\n# Destination Path: {}\n\n'.format(sourceFilePath,final_destination))
self.sftp.put(sourceFilePath, final_destination)
except Exception, e:
print(traceback.format_exc())
return
追溯:
# Source Path: C:\A\Long\Path\622-402_01.JPEG
# Destination Path: /var/www/WOOBLE-WAMBLER-SPAM-1235/622-402_01.JPEG
DEBUG:paramiko.transport.sftp:[chan 1] open('/var/www/WOOBLE-WAMBLER-SPAM-1235/622-402_01_swatch.JPEG', 'wb')
Traceback (most recent call last):
File "display_image.py", line 67, in putFiles
self.sftp.put(sourceFilePath, final_destination)
File "C:\Python27\lib\site-packages\paramiko\sftp_client.py", line 565, in put
fr = self.file(remotepath, 'wb')
File "C:\Python27\lib\site-packages\paramiko\sftp_client.py", line 245, in open
t, msg = self._request(CMD_OPEN, filename, imode, attrblock)
File "C:\Python27\lib\site-packages\paramiko\sftp_client.py", line 635, in _request
return self._read_response(num)
File "C:\Python27\lib\site-packages\paramiko\sftp_client.py", line 682, in _read_response
self._convert_status(msg)
File "C:\Python27\lib\site-packages\paramiko\sftp_client.py", line 710, in _convert_status
raise IOError(errno.EACCES, text)
IOError: [Errno 13] Permission denied
我看過的其他帖子:
有些帖子有點舊,但似乎表明 paramiko 沒有實現它? Fabric 實現了一個版本,但我不確定是否要添加更多依賴項。
(Pdb) import pkg_resources
(Pdb) pkg_resources.get_distribution('paramiko').version
'1.13.0'
1) 將文件夾從 /home/user/Desktop 移動到 /var/www 的 Cron 任務
2) 以 root 身份登錄。 (明顯的安全問題)
在主機服務器上運行sudo passwd root
,我現在可以使用 root 將文件傳輸到 /var/www。
我還將用戶添加到 www-data 並遞歸地 chown 文件和目錄,但我認為設置 root 密碼可以解決問題。
在 linux 上:如果您可以通過 ssh 登錄:
ls -ld /path/to/location
查看誰擁有該目錄並具有 r/w 權限。
bob@bob-p7-1298c:~$ ls -ld /var/www
drwxr-xr-x 3 root root 4096 Sep 24 10:39 /var/www
然后看看使用:
usermod
addgroup
useradd
chown
chmod
授予用戶 r/w 權限。
這可以通過以下方式完成:
看:
我對 sftp.get 有同樣的錯誤
我試圖做:
sftp.get('/remote_server/readme.txt', localpath='C:\\Users\\user1\\Desktop')
得到上面的錯誤:[Errno 13] 權限被拒絕
解決方法是我們需要指定包含文件名的整個路徑。
sftp.get('/remote_server/readme.txt', localpath='C:\\Users\\user1\\Desktop\\readme.txt')
我自己在 Windows 上收到“權限被拒絕”錯誤。 我的代碼看起來像這樣 -
sftp.put(sftp_local_path + "\\filename.txt", sftp_remote_path)
然后我像下面這樣改變它 -
with pysftp.Connection(host=sftp_host,username=sftp_user_id, password=sftp_pwd, port=sftp_port, cnopts=cnopts ) as sftp:
with sftp.cd(sftp_remote_path):
sftp.put(sftp_local_path + "\\filename.txt")
我能夠成功上傳文件。
使用 pysftp 來 put() 文件時,我遇到了相同的錯誤和非常相似的回溯。 結果我試圖 put() 一個文件,該文件與該 sftp 目錄中已經存在的文件具有相同的文件名。 在 put() 之前更改文件名為我解決了這個問題。
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.