[英]Rails API for fb login with Ionic
我想使用离子框架为fb登录构建一个rails api。 直到现在我已成功创建了一个网络基础应用程序,并且它已成功通过Facebook进行身份验证。
现在我想用基于离子的应用程序做同样的事情。
有问题吗?
无法在网上找到关于它的任何内容,也没有找到任何带离子的导轨的github项目(fb登录)。
我目前的代码:
控制器:
class SessionsController < ApplicationController
def create
user = User.from_omniauth(env["omniauth.auth"])
session[:user_id] = user.id
redirect_to root_url
end
def destroy
session[:user_id] = nil
redirect_to root_url
end
end
模型:
class User < ActiveRecord::Base
def self.from_omniauth(auth)
where(provider: auth.provider, uid: auth.uid).first_or_initialize do |user|
user.provider = auth.provider
user.uid = auth.uid
user.name = auth.info.name
user.oauth_token = auth.credentials.token
user.oauth_expires_at = Time.at(auth.credentials.expires_at)
user.save!
end
end
end
初始化:
OmniAuth.config.logger = Rails.logger
Rails.application.config.middleware.use OmniAuth::Builder do
provider :facebook, "123", "abc"
end
我不确定它是否可能......但我认为你不应该使用相同的逻辑。
Rails facebook omniauth流程是基于会话的,而Ionic应用程序主要是“访问令牌”,即您使用身份验证公开Rails API。
此外,在Ionic中您有一些优势:您可以使用Ionic Native Facebook Connect插件访问本机Facebook登录,这为已安装Facebook的用户提供了更好的用户体验。
我有同样的问题,我完成的工作是首先了解身份验证如何适用于单页应用程序。 为此,我建议您阅读“单个单页应用程序的身份验证” 。
我的最终解决方案如下:
我使用的工具:
您可以在https://github.com/muZk/rails5-api-jwt-facebook-auth上看到一个示例rails应用程序,用于检索有效的JWT令牌,并提供有效的facebook身份验证令牌
创建后端后,Ionic部分应该是这样的:
this.fb.login(['public_profile', 'user_friends', 'email'])
.then((res: FacebookLoginResponse) => post('your-rails-backend.com/api/auth/facebook', { access_token: FacebookLoginResponse.accessToken }))
.then(res => console.log('This is your JWT for your rails API:', res.accessToken))
我知道这不是一个复制粘贴解决方案,但我希望我能帮助你解决一些问题。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.