python通過paramiko實現,ssh功能import paramikossh =paramiko.SSHClient()#建立一個SSH連線物件ssh.set_missing_host_key_policy(paramiko.AutoAddPolicy())#允許串連不在KNOV_HOSTs檔案中的主機 自動添加ssh.connect(hostname='192.168.11.51',port=22,username='yjj',password='yjj')#串連,主機 連接埠 使用者名稱 密碼stdin,stdout,stderr=ssh.exec_command('df')#.exec_command 為執行命令,返回結果 ,標準輸入,標準輸出,標準錯誤,錯誤與輸出只會返回其一result=stdout.read()#擷取結果#result2=stdin.read()#擷取結果#result3=stderr.read()#擷取結果#print(result,result2,result3)result=result.decode()print(result)ssh.close()#關閉串連
ftp功能
import paramiko#建立一個傳輸通道對象transport=paramiko.Transport(('192.168.11.50',22))#傳輸模組 Transport 伺服器位址 連接埠transport.connect(username='root',password='yjj')#使用者名稱,,密碼sftp=paramiko.SFTPClient.from_transport(transport)#調用傳輸方法sftp.put('test2','/home/yjj/test2')#上傳檔案 ,本地路徑檔案 ,伺服器的路徑檔案sftp.get('/home/yjj/test1','test1')#下載檔案 ,伺服器的路徑檔案 ,本地路徑檔案
為了安全起見,不使用純文字密碼,採用 RSA 非對稱金鑰自動登陸
在linux下:產生密鑰
傳輸到要登陸的伺服器端:
傳輸成功就可以成功登陸伺服器上對應的使用者
如果是windows登陸linux
可以將私密金鑰複製到windows下
通過paramiko.RSAKey指定私密金鑰進行訪問
ssh功能:
import paramikopriv_key=paramiko.RSAKey.from_private_key_file('id_rsa')#指定私密金鑰檔案ssh=paramiko.SSHClient()#產生ssh對象ssh.set_missing_host_key_policy(paramiko.AutoAddPolicy())#允許串連不在KNOV_HOSTs檔案中的主機 自動添加ssh.connect(hostname='192.168.11.50',port=22,username='root',pkey=priv_key)#串連,主機 連接埠 使用者名稱 私密金鑰stdin,stdout,stderr=ssh.exec_command('df')#.exec_command 為執行命令,返回結果 ,標準輸入,標準輸出,標準錯誤,錯誤與輸出只會返回其一result=stdout.read()#擷取結果result=result.decode()print(result)ssh.close()#關閉串連
ftp功能:
import paramikopriv_key=paramiko.RSAKey.from_private_key_file('id_rsa')#指定私密金鑰檔案#建立一個傳輸通道對象transport=paramiko.Transport(('192.168.11.50',22))#傳輸模組 Transport 伺服器位址 連接埠transport.connect(username='root',pkey=priv_key)#使用者名稱,,私密金鑰sftp=paramiko.SFTPClient.from_transport(transport)#調用傳輸方法sftp.put('test2','/home/yjj/test2-2')#上傳檔案 ,本地路徑檔案 ,伺服器的路徑檔案sftp.get('/home/yjj/test1','test1-2')#下載檔案 ,伺服器的路徑檔案 ,本地路徑檔案with open('test1-2','r',encoding='utf-8') as f: s=f.readlines() print(s)