簡體   English   中英

通過SSL發布UTF-8時,在HEROKU上出現“ EOFError:文件已到達結尾”

[英]'EOFError: end of file reached' on HEROKU while posting UTF-8 via SSL

我在heroku上有一個奇怪的錯誤。 要重現它,我必須使用請求主體中的任何UTF-8字符來制作大型(超過幾個KB)的HTTPS POST。 這是一個例子:

require "net/https"
require "uri"

#Accutally I've ecountered this bug while posting to another server
url = URI.parse("https://api.heroku.com/myapps")

#It's Ukrainian 'oiced velar plosive G' letter
payload = "ґ"*10000
request = Net::HTTP::Post.new(url.path)
request.body = payload
http = Net::HTTP.new(url.host, url.port)
http.use_ssl = true
http.read_timeout = 500
http.start {|http| http.request request }

在本地計算機的irb上運行這樣的腳本會給我:

#<Net::HTTPUnauthorized 401 Unauthorized readbody=true> 

...這是預期的,但是在heroku cedar上,在“ heroku控制台”上運行它...大約60秒后,我得到:

EOFError: end of file reached
    from /usr/local/lib/ruby/1.9.1/openssl/buffering.rb:145:in `sysread_nonblock'
    from /usr/local/lib/ruby/1.9.1/openssl/buffering.rb:145:in `read_nonblock'
    from /usr/local/lib/ruby/1.9.1/net/protocol.rb:135:in `rbuf_fill'
    from /usr/local/lib/ruby/1.9.1/net/protocol.rb:116:in `readuntil'
    from /usr/local/lib/ruby/1.9.1/net/protocol.rb:126:in `readline'
    from /usr/local/lib/ruby/1.9.1/net/http.rb:2219:in `read_status_line'
    from /usr/local/lib/ruby/1.9.1/net/http.rb:2208:in `read_new'
    from /usr/local/lib/ruby/1.9.1/net/http.rb:1191:in `transport_request'
    from /usr/local/lib/ruby/1.9.1/net/http.rb:1177:in `request'
    from (irb):32:in `block in irb_binding'
    from /usr/local/lib/ruby/1.9.1/net/http.rb:627:in `start'
    from (irb):32
    from /app/vendor/bundle/ruby/1.9.1/gems/railties-3.2.7/lib/rails/commands/console.rb:47:in `start'
    from /app/vendor/bundle/ruby/1.9.1/gems/railties-3.2.7/lib/rails/commands/console.rb:8:in `start'
    from /app/vendor/bundle/ruby/1.9.1/gems/railties-3.2.7/lib/rails/commands.rb:41:in `<top (required)>'

我該怎么辦?

我必須將寶石版本添加到Gemfile中 ,因為默認Cedar的寶石是1.9.2(通過SSL傳遞UTF-8字符串存在錯誤)

source 'https://rubygems.org'
ruby "1.9.3"

gem 'rails', '3.2.7'
gem 'pg'
...

我認為,這應該可行:

require "net/https"
require "uri"

url = URI.parse("https://api.heroku.com/myapps")
#It's Ukrainian letter 'soft-G'
payload = "ґ"*10000
request = Net::HTTP::Post.new(url.path)
request.basic_auth 'youremail', 'yourpassword'
request.body = URI.encode(payload)
http = Net::HTTP.new(url.host, url.port)
http.use_ssl = true
http.read_timeout = 500
http.start {|http| http.request request }

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM