ホームページ >バックエンド開発 >Python チュートリアル >pysftp と Paramiko を使用して SFTP ホスト キーを安全に管理するにはどうすればよいですか?
Pysftp を使用した SFTP のホスト キーの管理: 詳細な検査
ホスト キーの検証は、安全な SFTP 接続を確立する際の重要な手順です。 pysftp は SFTP 接続を管理するための一般的なツールですが、ユーザーはホスト キーの処理で問題に遭遇することがよくあります。この記事は、これらの問題を詳しく分析し、包括的な解決策を提供することを目的としています。
Pysftp は、ホスト キー管理を含む SSH 機能を Paramiko ライブラリに依存しています。ただし、pysftp 自体にはホスト キーの処理に関して特定の制限があることに注意することが重要です。さらに、pysftp プロジェクトは非アクティブであるように見えるため、一部のユーザーは代わりに Paramiko を直接使用することを検討しています。 Paramiko は、ホスト キー管理の柔軟性と制御を向上させます。
CnOpts と信頼できるホスト キーについて
ホスト キーの問題に対する 1 つの解決策は、pysftp の CnOpts オブジェクトを利用することです。 。 CnOpts には、ユーザーが信頼できるホスト キーを管理できるようにする hostkeys 属性が含まれています。サーバーの公開キーを含むファイルへのパスを指定することにより、pysftp は接続確立プロセス中にホスト キーを検証できます:
cnopts = pysftp.CnOpts(knownhosts='known_hosts') with pysftp.Connection(host, username, password, cnopts=cnopts) as sftp: # ...
「known_hosts」ファイルには、次のサーバーの公開キーが含まれている必要があります。 format:
example.com ssh-rsa AAAAB3NzaC1yc2EAAAADAQAB...
このアプローチにより、pysftp は既知の信頼できるホスト キーに対してサーバーのホスト キーを検証します。 list.
ダイレクト ホスト キーの使用
外部ホスト キー ファイルを維持できない場合は、Paramiko を使用してコード内でホスト キーを直接指定できます。
from base64 import decodebytes # ... keydata = b"""AAAAB3NzaC1yc2EAAAADAQAB...""" key = paramiko.RSAKey(data=decodebytes(keydata)) cnopts = pysftp.CnOpts() cnopts.hostkeys.add('example.com', 'ssh-rsa', key) with pysftp.Connection(host, username, password, cnopts=cnopts) as sftp: # ...
ただし、このアプローチでは、pysftp 0.2.9 で警告がトリガーされる可能性があります。 bug.
ホスト キーを外部から取得する
ssh-keyscan ツールを使用してホスト キーを自動的に取得することもできます:
# Retrieve host key using ssh-keyscan ssh-keyscan example.com
このコマンドは、ホストキーを必要な形式で出力します。 PowerShell で出力をファイルにリダイレクトすると問題が発生する可能性があることに注意してください。
注意事項と考慮事項
ホスト キーの検証を扱うときは注意が必要です。ホスト キーのチェックを無効にする (cnopts.hostkeys = None に設定する) と、セキュリティが大幅に侵害されるため、避けてください。
さらに、ホスト キーをリモートで取得することは、潜在的な攻撃に対して脆弱になるため、危険を伴う可能性があります。セキュリティを強化するには、サーバーの管理者から直接ホスト キーを取得します。
結論として、pysftp を使用して SFTP 接続のホスト キーを管理するには、利用可能なオプションを慎重に検討する必要があります。 CnOpts を活用し、pysftp に関連する制限とバグを理解することで、ユーザーは安全で信頼性の高いホスト キー検証メカニズムを実装できます。
以上がpysftp と Paramiko を使用して SFTP ホスト キーを安全に管理するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。