2012-05-09 1 views
1

Je lance l'exemple de ruby ​​openId suivant sur sinatra sur une image Ubuntu.ruby ​​sinatra L'application openid répond avec "Nonce déjà utilisé ou hors de portée"

%w(rubygems sinatra openid openid/store/filesystem).each { |lib| require lib} 

REALM = 'http://localhost:4567' 
RETURN_TO = "#{REALM}/complete" 

get '/loginform' do 
    erb :loginform 
end 


post '/login' do 
    checkid_request = openid_consumer.begin(params[:openid_identifier]) 
    redirect checkid_request.redirect_url(REALM, RETURN_TO) if checkid_request.send_redirect?(REALM, RETURN_TO) 
    checkid_request.html_markup(REALM, RETURN_TO) 
end 

get '/complete' do 
    response = openid_consumer.complete(params, RETURN_TO) 
    return 'You are logged in!' if response.status == OpenID::Consumer::SUCCESS 
    msg=response.message 
    <<-eos 
    Could not log on with your OpenID due to #{msg} 
    eos 
end 

def openid_consumer 
    @consumer = OpenID::Consumer.new(session, OpenID::Store::Filesystem.new("#{File.dirname(__FILE__)}/.tmp/openid")) if @consumer.nil? 
    return @consumer 
end 


enable :inline_templates 

__END__ 

@@ layout 
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" 
     "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> 
<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en" lang="en"> 
<head> 
    <meta http-equiv="content-type" content="text/html;charset=UTF-8" /> 
    <title>got openid?</title> 
</head> 
<body> 
    <%= yield %> 
</body> 
</html> 


@@ loginform 
<form method="post" accept-charset="UTF-8" action='/login'> 
    Identifier: 
    <input type="text" class="openid" name="openid_identifier" /> 
    <input type="submit" value="Verify" /> 
</form> 

en entrant l'URL de Google (https://www.google.com/accounts/o8/id) Je redircted à Google, entrez mes lettres de créance, mais au lieu d'être l'accès accordé, je reçois:

déjà utilisé ou Nonce hors de portée: "2012-05-09T13: 50: xxxxxxxxxxxxxxx"

(BTW, j'exécute le programme en utilisant Ruby "fusil de chasse" "rubis" pas). Quelqu'un peut-il me donner un aperçu de la signification de la sortie ainsi qu'un remède? Merci!

Répondre

1

Résolu! Le problème provient du Store privliges. Je pense que c'est principalement un problème d'Ubuntu.

Je changé ceci:

@consumer = OpenID::Consumer.new(session, OpenID::Store::Filesystem.new("#{File.dirname(__FILE__)}/.tmp/openid")) if @consumer.nil? 

Dans ce (sans état):

@consumer = OpenID::Consumer.new(session, nil) if @consumer.nil? 

et cela a fonctionné!