也许我只是盲目,但许多关于在 Net::HTTP 中传递标头的帖子都遵循以下内容
require 'net/http'
uri = URI("http://www.ruby-lang.org")
req = Net::HTTP::Get.new(uri)
req['some_header'] = "some_val"
res = Net::HTTP.start(uri.hostname, uri.port) {|http|
http.request(req)
}
puts res.body
(来自Ruby - 发送带有标题隐喻的 GET 请求的答案)
并来自 Net::HTTP 文档 ( https://docs.ruby-lang.org/en/2.0.0/Net/HTTP.html )
uri = URI('http://example.com/cached_response')
file = File.stat 'cached_response'
req = Net::HTTP::Get.new(uri)
req['If-Modified-Since'] = file.mtime.rfc2822
res = Net::HTTP.start(uri.hostname, uri.port) {|http|
http.request(req)
}
open 'cached_response', 'w' do |io|
io.write res.body
end if res.is_a?(Net::HTTPSuccess)
但是,当您可以通过以下方式传递标头时,执行上述操作有什么好处?
options = {
'headers' => {
'Content-Type' => 'application/json'
}
}
request = Net::HTTP::Get.new('http://www.stackoverflow.com/', options['headers'])
这允许您参数化标头,并且可以非常轻松地允许多个标头。
我的主要问题是,在创建 Net::HTTP::Get 时传递标头与在创建 Net::HTTP::Get 后传递标头有什么优势
Net::HTTPHeader 已经开始并在函数中分配标头
def initialize_http_header(initheader)
@header = {}
return unless initheader
initheader.each do |key, value|
warn "net/http: duplicated HTTP header: #{key}", uplevel: 1 if key?(key) and $VERBOSE
if value.nil?
warn "net/http: nil HTTP header: #{key}", uplevel: 1 if $VERBOSE
else
value = value.strip # raise error for invalid byte sequences
if value.count("\r\n") > 0
raise ArgumentError, 'header field value cannot include CR/LF'
end
@header[key.downcase] = [value]
end
end
end
所以这样做
request['some_header'] = "some_val"
几乎就像代码重复。