13

アクセスする必要のあるSSL対応ポートを持つサーバーとのTCP接続を確立する必要があります。

XMLファイルを送信し、サーバーから応答を取得する必要があります。

SSLを有効にする前は、以下のコードを使用してサーバーからデータを取得することができました。

require 'socket'
myXML = 'test_xml' 
host = 'myhost.com'   
port = 12482               

socket = TCPSocket.open(host,port)  # Connect to server  
socket.send(myXML, 0)
response = socket.recvfrom(port)
puts response
socket.close

これで、接続を確立するために必要な「certi.pfx」ができました。my_xmlデータを送信して応答を取得します。これはどのように行うことができますか。

また、「pem」ファイルと「key」ファイルがあるかどうか、接続を確立する方法、my_xmlデータを送信して応答を取得する方法についても知りたいです。

助けてください。

4

2 に答える 2

22
require 'socket'
require 'openssl'

myXML = 'my_sample_data'
host = 'my_host.com'
port = my_port                

socket = TCPSocket.open(host,port)
ssl_context = OpenSSL::SSL::SSLContext.new()
ssl_context.cert = OpenSSL::X509::Certificate.new(File.open("certificate.crt"))
ssl_context.key = OpenSSL::PKey::RSA.new(File.open("certificate.key"))
ssl_context.ssl_version = :SSLv23
ssl_socket = OpenSSL::SSL::SSLSocket.new(socket, ssl_context)
ssl_socket.sync_close = true
ssl_socket.connect

ssl_socket.puts(myXML)
while line = ssl_socket.gets
  p line
end
ssl_socket.close
于 2012-10-11T11:11:36.623 に答える
5

Like this:

  sock = TCPSocket.new('hostname', 443)
  ctx = OpenSSL::SSL::SSLContext.new
  ctx.set_params(verify_mode: OpenSSL::SSL::VERIFY_PEER)
  @socket = OpenSSL::SSL::SSLSocket.new(sock, ctx).tap do |socket|
    socket.sync_close = true
    socket.connect
  end
于 2012-10-11T10:08:24.203 に答える