RUBY - SSL, базовая аутентификация и POST - PullRequest
7 голосов
/ 01 августа 2011

Мне очень тяжело с этим - кажется, есть несколько фрагментов кода, которые я не могу собрать вместе.Я просто пытаюсь POST пары ключ / значение, но получаю Connection refused - connect(2) (Errno::ECONNREFUSED).Помогите!

require 'net/http'
require 'net/https'
require 'uri'

@http = Net::HTTP.new('https://my.url.com/path', 443)
@http.use_ssl = true
@http.start() { |http|
    req = Net::HTTP.post_form(
        URI.parse('https:///my.url.com/path'),
        {'key1' => 'value1', 'key2' => 'value2'}
    )
    req.basic_auth 'username', 'password'
    response = http.request(req)
    puts response.body      
}

Ответы [ 2 ]

18 голосов
/ 01 августа 2011

HTTP # post_form будет выполняться напрямую, игнорируя другие ваши настройки.Попробуйте вместо этого:

require 'net/http'
require 'uri'

url = URI.parse('https://my.url.com/path')
req = Net::HTTP::Post.new(url.path)
req.basic_auth 'user', 'pass'
req.use_ssl = true
req.form_data({'key1' => 'val1', 'key2' => 'val2'})

resp = Net::HTTP.new(url.host, url.port).start {|http| http.request(req) }
puts resp

Вероятно, у вас возникнут проблемы с сертификатами сервера.См. Мой пост для получения инструкций о том, как их получить / настроить.

7 голосов
/ 08 сентября 2011

Нашел этот вопрос во время моего поиска решения, и, чтобы быть ясным, тиснение кода не работает. Я получил работу (внутри большого приложения Sinatra):

require 'net/http'
require 'net/https'
require 'uri'

set :api_username, 'usr'
set :api_passwor, 'pswd'

def do_auth_check params
    puts params.inspect

    url = URI.parse("https://my_auth_site.com:443/authenticate")
    req = Net::HTTP::Post.new(url.path)
    req.basic_auth options.api_username, options.api_password
    req.set_form_data({'username' => params[:name], 'password' => params[:pass]})

    sock = Net::HTTP.new(url.host, url.port)
    sock.use_ssl = true
    res = sock.start {|http| http.request(req) }

    # you're on your own down here to identify success/failure, but for me 2xx/3xx was ok and 401/404/500/etc would be failure
    return true if res.code.to_i < 400
    return "Error logging in"
end
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...