腾讯公司最近开放了QQ登陆,这对广大站长是个好消息,从此实现QQ账号登陆您的网站不再是梦想。但是遍寻腾讯的SDK文档,并不见Ruby的实现,这对Ruby爱好者可不是个好消息。经过好几天的摸索,我终于成功实现了QQ登陆了。下面把代码贴出来。
首先要安装oauth
gem install oauth
写上配置信息
CONSUMER_OPTIONS = {
:site => "http://openapi.qzone.qq.com",
:request_token_path => "/oauth/qzoneoauth_request_token",
:access_token_path => "/oauth/qzoneoauth_access_token",
:authorize_path => "/oauth/qzoneoauth_authorize",
:http_method => :get,
:scheme => :query_string,
:nonce => Base64.encode64(OpenSSL::Random.random_bytes(32)).gsub(/\W/, \'\')[0, 32] }
QQ_KEY = ×××
QQ_SECRET = \'×××××××××××××××××××××××××××××\'
其中,QQ_KEY和QQ_SECRET换上你们自己的。
#第一个方法
def login_from_qq
consumer = OAuth::Consumer.new(QQ_KEY, QQ_SECRET, CONSUMER_OPTIONS)
request_token = consumer.get_request_token()
session[:qqtoken] = request_token.token
session[:qqsecret] = request_token.secret淘宝网女装夏装新款
redirect_to request_token.authorize_url + "&oauth_consumer_key=205799&oauth_callback=http%3A%2F%2Flocalhost:3000%2Faccount%2Flogin_from_qq_callback"
end
#用户点击授权后,调用回调方法
def login_from_qq_callback
consumer = OAuth::Consumer.new(QQ_KEY, QQ_SECRET, CONSUMER_OPTIONS)
request_token = ::OAuth::RequestToken.new(consumer, session[:qqtoken], session[:qqsecret])
access_token = request_token.get_access_token(:oauth_vericode => params[:oauth_vericode])
response = access_token.get("/user/get_user_info?openid=#{params[:openid]}")
return_hash = ActiveSupport::JSON.decode(response.body)
nickname = User.find_by_name(return_hash["nickname"])
....
end
腾讯的接口有一个参数名字比较怪异,别人都叫做:oauth_verifier,他偏要叫做:oauth_vericode,这 要进行一个oauth gem库的crack,进入ruby的gem路径,打开/oauth-0.4.4/lib/oauth/client/helper.rb文件,在 oauth_parameters方法下加上一行代码,例如:
wander和imagin有什么区别\'oauth_verifier\' => options[:oauth_verifier],
\'oauth_vericode\' => options[:oauth_vericode],