2013-06-12 15 views
6

ben yakut mücevher 'twitter' kullanmaya çalışıyorum ama bilinmeyen nedenlerle ben çalışmak için alınamıyor. İşte Yakut Gem Heyecan - Sertifika doğrulama başarısız (Twitter :: Hata :: ClientError)

.rb kodudur:

require 'twitter' 

puts "Greetings, World!" 
puts "Checkpoint 1" 
Twitter.configure do |config| 
    config.consumer_key = "xxxxxxx" #removed for posting 
    config.consumer_secret = "xxxxxxx" #removed for posting 
    config.oauth_token = "xxxxxxx" #removed for posting 
    config.oauth_token_secret = "xxxxxxx" #removed for posting 
end 
Twitter.verify_credentials 
puts "Checkpoint 2" 

ve aşağıdaki hatayı alıyorum: belki ... Bir yakut deneyimsizim

Greetings, World! 
Checkpoint 1 
C:/Ruby200-x64/lib/ruby/2.0.0/net/http.rb:918:in `connect': SSL_connect returned=1 errno=0 state=SSLv3 read server certificate B: certificate verify failed (Twitter::Error::ClientError) 
from C:/Ruby200-x64/lib/ruby/2.0.0/net/http.rb:918:in `block in connect' 
from C:/Ruby200-x64/lib/ruby/2.0.0/timeout.rb:66:in `timeout' 
from C:/Ruby200-x64/lib/ruby/2.0.0/net/http.rb:918:in `connect' 
from C:/Ruby200-x64/lib/ruby/2.0.0/net/http.rb:862:in `do_start' 
from C:/Ruby200-x64/lib/ruby/2.0.0/net/http.rb:851:in `start' 
from C:/Ruby200-x64/lib/ruby/2.0.0/net/http.rb:1367:in `request' 
from C:/Ruby200-x64/lib/ruby/2.0.0/net/http.rb:1126:in `get' 
from C:/Ruby200-x64/lib/ruby/gems/2.0.0/gems/faraday-0.8.7/lib/faraday/adapter/net_http.rb:73:in `perform_request' 
from C:/Ruby200-x64/lib/ruby/gems/2.0.0/gems/faraday-0.8.7/lib/faraday/adapter/net_http.rb:38:in `call' 
from C:/Ruby200-x64/lib/ruby/gems/2.0.0/gems/faraday-0.8.7/lib/faraday/response.rb:8:in `call' 
from C:/Ruby200-x64/lib/ruby/gems/2.0.0/gems/faraday-0.8.7/lib/faraday/response.rb:8:in `call' 
from C:/Ruby200-x64/lib/ruby/gems/2.0.0/gems/faraday-0.8.7/lib/faraday/response.rb:8:in `call' 
from C:/Ruby200-x64/lib/ruby/gems/2.0.0/gems/faraday-0.8.7/lib/faraday/request/url_encoded.rb:14:in `call' 
from C:/Ruby200-x64/lib/ruby/gems/2.0.0/gems/faraday-0.8.7/lib/faraday/request/multipart.rb:13:in `call' 
from C:/Ruby200-x64/lib/ruby/gems/2.0.0/gems/twitter-4.8.0/lib/twitter/request/multipart_with_file.rb:14:in `call' 
from C:/Ruby200-x64/lib/ruby/gems/2.0.0/gems/faraday-0.8.7/lib/faraday/connection.rb:247:in `run_request' 
from C:/Ruby200-x64/lib/ruby/gems/2.0.0/gems/faraday-0.8.7/lib/faraday/connection.rb:100:in `get' 
from C:/Ruby200-x64/lib/ruby/gems/2.0.0/gems/twitter-4.8.0/lib/twitter/client.rb:108:in `request' 
from C:/Ruby200-x64/lib/ruby/gems/2.0.0/gems/twitter-4.8.0/lib/twitter/client.rb:66:in `get'   
from C:/Ruby200-x64/lib/ruby/gems/2.0.0/gems/twitter-4.8.0/lib/twitter/api/utils.rb:82:in `object_from_response' 
from C:/Ruby200-x64/lib/ruby/gems/2.0.0/gems/twitter-4.8.0/lib/twitter/api/users.rb:50:in `verify_credentials' 
from C:/Ruby200-x64/lib/ruby/gems/2.0.0/gems/twitter-4.8.0/lib/twitter.rb:60:in `method_missing' 
from C:/Ruby200-x64/AppCode/twitter_connect.rb:13:in `<main>' 

ve müşteri hatasının mantıklı olamaz Ben bir şey özlüyorum. Oauth kimlik bilgilerinin python'da çalıştığını da doğruladım.

Şimdiden teşekkürler ve senden yardım bekliyoruz.

cevap

9

Benim kendi soru çözmeyi başardı. Aynı sorun aşağıdaki kullanmayı deneyin sahip olanlar için:

OpenSSL::SSL::VERIFY_PEER = OpenSSL::SSL::VERIFY_NONE 

O SSL güvenliği devre dışı bırakır ama sorun giderme işlemine süreci sağlar. Temel sorun eski bir SSL'dir.

+1

Bu hatayı giderir, ancak bunu gerçekten yapmamalısınız http://jamesgolick.com/2011/2/15/verify-none..html – jordelver

1

Ben de yakut çok yeniyim ama Mac kullanıyorsunuz? Eski SSL sertifikası dosyaları nedeniyle olabilir. İşte benim için problemi çözen talimatların bir bağlantısı. http://railsapps.github.io/openssl-certificate-verify-failed.html

+0

Ben bağlantıyla ile herhangi bir şans yoktu pencereler 7. kullanmak ve benim yol değişkenleri ayarlanır doğruladı. Ayrıca ruby ​​2.0'ı kaldırdım ve 1.93 ruby'yi yükledim ve aynı problemle karşılaşıyorum. Tweet yukarı ve koşuyorum. YARDIM ET! – tjrburgess