2011-08-02 12 views
5

私はnet-sshのドキュメントを読みましたが、私はまだ困惑しています。手動で(ssh -i ...を使用して)認証することができます。また、キーをファイルに置き、:keysパラメータを使用して認証することもできます。しかし、:keysパラメータを使用したくないので、:key_dataパラメータを使用します。誰かが実用的な例を与えることができますか?なんらかの理由で、key_dataに文字列を直接供給していないため、「PUBキーもPRIVキー::入れ子asn1エラーもありません」というエラーが表示されます。もちろん、私はそれをgoogled、それは基本的にPEM形式でキーを確認するように指示します。もちろん、そうです。何か案は?必要に応じてもっと詳細な情報を提供することができます。Rubyとnet-sshを使用して、Net :: SSH.startでkey_dataパラメータを使用して認証するにはどうすればよいですか?

答えて

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 
+0

'/usr/share/ruby/2.0/socket.rb:232:inを取得'getaddrinfo':ArrayをStringに暗黙的に変換しない(TypeError) ' – sixty4bit

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 
関連する問題