Bug #10054
closedNet::HTTPGenericRequest sets host even if it was set before by user
Description
# there is SSH tunnel that forwards 127.0.0.1:9293 to google.com:80
request = Net::HTTP::Post.new(URI("http://127.0.0.1:9293")).tap do |req|
req.form_data = {q: "ruby"}
req["Host"] = "google.com"
end
This code ignores host that was already set (it uses "#{host}:#{uri}"):
Net::HTTP.start(uri.hostname, uri.port) { |http| http.request(request) }
I encountered this bug when tried to connect to remote server using SSH tunnel (/etc/hosts isn't available to edit).
Resolution:
https://bugs.ruby-lang.org/projects/ruby-trunk/repository/entry/lib/net/http/generic_request.rb line 119
def exec(sock, ver, path) #:nodoc: internal use only
- if @uri
+ if @uri && !self['host']
if @uri.port == @uri.default_port
Updated by naruse (Yui NARUSE) over 10 years ago
- Status changed from Open to Feedback
Why don't you use http_proxy?
Updated by semenyukd (Dmitriy Semenyuk) over 10 years ago
Yui NARUSE wrote:
Why don't you use http_proxy?
I need this only for some requests (imagine database that stores URLs, headers and request bodies) so adding http_proxy makes code more difficult.
Updated by naruse (Yui NARUSE) over 10 years ago
- Status changed from Feedback to Closed
- % Done changed from 0 to 100
Applied in changeset r47077.
-
lib/net/http/generic_request.rb (Net::HTTP::GenericRequest#exec):
handle req['host'] in update_uri. -
lib/net/http/generic_request.rb
(Net::HTTP::GenericRequest#update_uri):
use req['host'] if it is explicitly set. Even if URI is given,
it is already used for the initial value of req['host'].
Therefore overwritten value should be respected. [Bug #10054]