私はnet-sshのドキュメントを読みましたが、私はまだ困惑しています。手動で(ssh -i ...を使用して)認証することができます。また、キーをファイルに置き、:keysパラメータを使用して認証することもできます。しかし、:keysパラメータを使用したくないので、:key_dataパラメータを使用します。誰かが実用的な例を与えることができますか?なんらかの理由で、key_dataに文字列を直接供給していないため、「PUBキーもPRIVキー::入れ子asn1エラーもありません」というエラーが表示されます。もちろん、私はそれをgoogled、それは基本的にPEM形式でキーを確認するように指示します。もちろん、そうです。何か案は?必要に応じてもっと詳細な情報を提供することができます。Rubyとnet-sshを使用して、Net :: SSH.startでkey_dataパラメータを使用して認証するにはどうすればよいですか?
5
A
答えて
9
私はこの質問をかなり古くから見ていますが、私は同じ問題を抱えていて、ちょうど解決しました。
次のコードでは、RSAキーを含む文字列はどこにもインデントされていないことに注意してください。キーの2行目には先頭にスペースがありません。 TextMateは、キーを貼り付けたときにこれを貼り付けました。削除したところ、魅力的でした。私は、ライブラリの周りに掘った後、自分自身を発見し、もう少し情報を追加している
#!/usr/bin/env ruby
require 'rubygems'
require 'net/ssh'
HOST = '172.20.0.31'
USER = 'root'
KEYS = [ "-----BEGIN RSA PRIVATE KEY-----
MIIEogIBAAKCAQEAqccvUza8FCinI4X8HSiXwIqQN6TGvcNBJnjPqGJxlstq1IfU
kFa3S9eJl+CBkyjfvJ5ggdLN0S2EuGWwc/bdE3LKOWX8F15tFP0=
-----END RSA PRIVATE KEY-----" ]
Net::SSH.start(HOST, USER, :key_data => KEYS, :keys_only => TRUE) do|ssh|
result = ssh.exec!('ls')
puts result
end
6
...
2.9.2以来、あなたの意図はkey_dataで提供される唯一のキーを使用する場合、あなたkey_dataを読み込む前にブランクのキーセットを指定する必要があります。そうしないとデフォルトのキーが読み込まれます。
私の場合、ロードしようとしたアイデンティティファイルの1つはパスフレーズで保護されていたので、自分のパスフレーズを求めましたが、私の意図はそのファイルを全く使わないことでした。上記の例を使用して
、2.9.2で、あなたはこのような何かを行うことによって同じ効果を得ることができます。
#!/usr/bin/env ruby
require 'rubygems'
require 'net/ssh'
HOST = '172.20.0.31'
USER = 'root'
KEYS = [ "-----BEGIN RSA PRIVATE KEY-----
MIIEogIBAAKCAQEAqccvUza8FCinI4X8HSiXwIqQN6TGvcNBJnjPqGJxlstq1IfU
kFa3S9eJl+CBkyjfvJ5ggdLN0S2EuGWwc/bdE3LKOWX8F15tFP0=
-----END RSA PRIVATE KEY-----" ]
Net::SSH.start(HOST, USER, :keys => [], :key_data => KEYS, :keys_only => TRUE) do|ssh|
result = ssh.exec!('ls')
puts result
end
関連する問題
- 1. Net :: HTTPでPOSTリクエストのトークンを使用して認証するにはどうすればよいですか?
- 2. ノードアプリケーションでDjango認証を使用してユーザーを認証するにはどうすればよいですか?
- 3. ホットタオルでロールを使用してWindows認証を使用するにはどうすればよいですか?
- 4. iOS SDKを使用してWeChatで認証とログインを行うにはどうすればよいですか?
- 5. .netでServiceAccountを使用してGoogle OAuth2を使用するにはどうすればよいですか?
- 6. Javascript:パラメータを使用して関数でオブジェクトプロパティを使用するにはどうすればよいですか?
- 7. NTLMを使用してWCF Webサービスでコンソールアプリケーションを認証するにはどうすればよいですか?
- 8. PythonでWindows認証を使用してMSSQLにログインするにはどうすればよいですか?
- 9. google sdkを使用してVM内で認証を行うにはどうすればよいですか?
- 10. PHPのSDKを使用してFacebookで再認証を行うにはどうすればよいですか?
- 11. Rails REST APIアプリケーションでDeviseを使用して認証するにはどうすればよいですか?
- 12. UBOOTコンソールのスペースを使用してパラメータを使用するにはどうすればよいですか?
- 13. PyMongoを使用してユーザーがデータベースで認証されているかどうかを確認するにはどうすればよいですか?
- 14. SignalR(.NETクライアント)でカスタム基本認証を使用するにはどうすればよいですか?
- 15. ORACLE APEX 5 - 認証を使用してカスタムログインページを作成するにはどうすればよいですか?
- 16. PHPを使用してLinkedin URLを認証するにはどうすればよいですか?
- 17. Dropwizardを使用してHMAC認証をテストするにはどうすればよいですか?
- 18. FacebookログインAPIを使用してXMPPユーザーを認証するにはどうすればよいですか?
- 19. APIキーを使用してGitHubを認証するにはどうすればよいですか?
- 20. URLを使用してJSONオブジェクトをパラメータとして渡すにはどうすればよいですか?
- 21. Windows認証を使用してサービスファブリックにパブリッシュするにはどうすればよいですか?
- 22. jQueryを使用してWindows認証をWebサービスに渡すにはどうすればよいですか?
- 23. node.js + Passportを使用してIOSでfacebook loginを認証するにはどうすればいいですか
- 24. Azureアクティブディレクトリを使用してアプリケーションで認証を実装するにはどうすればいいですか
- 25. RVMを使用してrubyとgemをアンインストールするにはどうすればよいですか?
- 26. Aptana Studio 3とrbenvを使用してRubyスクリプトをデバッグするにはどうすればよいですか?
- 27. C#でDLLImportを構造体のパラメータとして使用するにはどうすればよいですか?
- 28. select文でパラメータとしてpartition nameを使用するにはどうすればよいですか?
- 29. HIMAGELIST(SetupDiGetClassImageListから)を.NET ImageListとして使用するにはどうすればよいですか?
- 30. Windows APIを使用してARMを使用しているかどうかを確認するにはどうすればよいですか?
'/usr/share/ruby/2.0/socket.rb:232:inを取得'getaddrinfo':ArrayをStringに暗黙的に変換しない(TypeError) ' – sixty4bit