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 11 years ago
          
          
        
        
      
      - Status changed from Open to Feedback
 
Why don't you use http_proxy?
        
          
          Updated by semenyukd (Dmitriy Semenyuk) over 11 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) about 11 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]