[RoR] FB會員登入APP -- YTChen
- 取得連結
- X
- 以電子郵件傳送
- 其他應用程式
St ep1: 裝載模板
git clone https://github.com/kaochenlong/rails_app
cp -r rails_app/ YTChen
bundle install
St ep2: Devise 使用初步設定
使用 devise https://github.com/plataformatec/devise
用 devise 串接 facebook 登入
寄信參考資料
去Gemfile裡面找個空位加上
gem 'devise'
然後
bundle install
然後產生 devise 的設定檔
rails generate devise:install
data:image/s3,"s3://crabby-images/75e38/75e38c797f5feec4940c63e6e414aa6e59ad4314" alt=""
Step3: 產生一個devise的MODEL 叫做 User
- rails generate devise User
data:image/s3,"s3://crabby-images/5caa7/5caa71a020d0d5131121763be3094e928104f935" alt=""
如果上面用的 MODEL 的名字是 User,那之後就會有以下好用的方法:
user_signed_in? 詢問是否已登入
current_user 取得目前登入的使用者
這些都是使用 devise 這個 gem 送的
做完這步驟後要
- rake db:migrate
因為這個指令他會幫忙做一個migration
Step4: 建一個首頁
- rails generate controller welcome
data:image/s3,"s3://crabby-images/fe8d4/fe8d46d8a22d57e26bdd7a42dcd9e73443432cd7" alt=""
去app/views/welcome資料夾下面建一個 index.html.erb檔
data:image/s3,"s3://crabby-images/dc9a8/dc9a8ba2b54eaa43551655060be712a87ea0eada" alt=""
接著去
config/routes.rb裡面把首頁指到welcome/底下的index
加入這一行即可
root 'welcome#index'
撰寫剛剛的 index.html.erb 檔案內容
- <% if user_signed_in? %>
- <h1> <%= current_user.email %>,你好 </h1>
- <%= link_to '登出', destroy_user_session_path, method: :delete %>
- <% else %>
- <%= link_to '註冊', new_user_registration_path %>
- <%= link_to '登入', new_user_session_path %>
- <% end %>
User會員登入做完了
接著做網站後台
Step5: 網站後台
首先先產生一個admin的controller:
- rails g controller admin/dashboard
接著在views/admin/dashboard/ 新增一個 index.html.erb
data:image/s3,"s3://crabby-images/2c5de/2c5de88909b017acff6b6f09b1ae256c556773f1" alt=""
加入產品products
- rails g scaffold admin/products name price:integer publish_date:date
- rake db:migrate
再去指令路徑 config/routes.rb 裡面加入
- namespace :admin do
- root 'dashboard#index'
- resources :products
- end
[筆記]導入bootstrap
使用方法看這篇
Gemfile裡面加上這個
- gem 'bootstrap-sass'
然後做
- bundle install
接著去app/assets/stylesheets/application.scss 裡面
加入兩行程式
- @import "bootstrap-sprockets";
- @import "bootstrap";
到 app/assets/javascripts/application.js 裡面
加上這兩行
- //= require jquery
- //= require bootstrap-sprockets
到這一步驟就可以使用bootstrap了
實驗看看去剛剛的
app/views/admin/products/index.html.erb裡面
<table>加上一個class成這樣<table class="table">
data:image/s3,"s3://crabby-images/9584e/9584ef0eedd8fac0715eef2717d9538770a865a3" alt=""
目前可以看到的畫面長這樣: data:image/s3,"s3://crabby-images/85c4f/85c4f722843ad64621445bdc2e6c90e7b760a277" alt=""
data:image/s3,"s3://crabby-images/85c4f/85c4f722843ad64621445bdc2e6c90e7b760a277" alt=""
加一個門神來檢查有沒有登入
- 登入檢查
- before_action :authenticate_user!
這行程式碼把它貼到
app/controller/admin/products_controller.rb
以及
app/controller/admin/dashboard_controller.rb
Step6: FB登入
用 devise 串接 facebook 登入參考資料
- step 6-0:
facebook 會有 user name 跟 user image欄位
所以我們可以先把User 除了email跟password之外再另建name跟image這兩個欄位
先使用 rails g migration Useru
產生一個migration檔案(檔案名稱不要跟user撞到所以我叫它 Useru)
然後去 db/migrate/ 找到migration檔案並且修它
data:image/s3,"s3://crabby-images/cee17/cee17f3fc7112b5b5ae56039149e6bd75e98078c" alt=""
加上 add_column :users(devise產生的model名稱), :想要的欄位 , 資料型態
做完後 rake db:migrate
- step 6-1:
Gemfile 裡面加入
- gem 'omniauth-facebook'
然後 bundle install
- step 6-2:
- rails g migration AddColumnsToUsers provider uid
- rake db:migrate
data:image/s3,"s3://crabby-images/f3ed6/f3ed647748213cf6ca00353962a88af4083a4610" alt=""
- step 6-3:
去 config/initializers/devise.rb: 加上這行
- config.omniauth :facebook, "APP_ID", "APP_SECRET"
這裏需要我的APP_ID 以及 APP_SECRET
這兩個要去 Facebook developer申請
data:image/s3,"s3://crabby-images/3d2ff/3d2ff4b740c78f6ef130da7a8c7fda6d04ecd124" alt=""
config.omniauth :facebook 把App ID App Secret 申請後的頁面
data:image/s3,"s3://crabby-images/a61bd/a61bde1dfed8f1b52bc6bd35def4ea77ebe6bebf" alt=""
按下 Add Platform
data:image/s3,"s3://crabby-images/e93ff/e93ff0657baee90842633417f780234dcd33c8e5" alt=""
點選 Website
data:image/s3,"s3://crabby-images/a74d5/a74d5f3558090e2af1175a010f9958f68e4574b1" alt=""
data:image/s3,"s3://crabby-images/a0f80/a0f8035bb3798be068b002d008e6d126358181c1" alt=""
去App Details
data:image/s3,"s3://crabby-images/0fb80/0fb807f5879a0a17984d339490a2509f730706b5" alt=""
加入1024 x 1024的 icon
data:image/s3,"s3://crabby-images/e7cd4/e7cd4f6e2ce5a0df174cc714360e403a0050110d" alt=""
- step 6-4:
去app/models/user.rb 加入這一行
- devise :omniauthable, :omniauth_providers => [:facebook]
- step 6-5:
config/routes.rb裡面加入
- devise_for :users, :controllers => { :omniauth_callbacks => "users/omniauth_callbacks" }
這裏要小心 devise_for :users 已經有了!所以要把上面那個舊的刪掉!
才不會在rake db:migrate時候出問題!
data:image/s3,"s3://crabby-images/a3725/a3725bb990e54a43ad744c9868e87834b9aadfcf" alt=""
- step 6-6:
先去 app/controllers/建立一個資料夾 users/
去app/controllers/users/裡面建立一個新檔案
檔名叫做 omniauth_callbacks_controller.rb
(add the file "app/controllers/users/omniauth_callbacks_controller.rb")
檔案裡面寫
- class Users::OmniauthCallbacksController < Devise::OmniauthCallbacksController
- def facebook
- # You need to implement the method below in your model (e.g. app/models/user.rb)
- @user = User.from_omniauth(request.env["omniauth.auth"])
- if @user.persisted?
- sign_in_and_redirect @user, :event => :authentication #this will throw if @user is not activated
- set_flash_message(:notice, :success, :kind => "Facebook") if is_navigational_format?
- else
- session["devise.facebook_data"] = request.env["omniauth.auth"]
- redirect_to new_user_registration_url
- end
- end
- end
- step 6-7:
去app/models/user.rb 加上這個
- def self.from_omniauth(auth)
- where(provider: auth.provider, uid: auth.uid).first_or_create do |user|
- user.email = auth.info.email
- user.password = Devise.friendly_token[0,20]
- user.name = auth.info.name # assuming the user model has a name
- user.image = auth.info.image # assuming the user model has an image
- end
- end
測試看看!!
data:image/s3,"s3://crabby-images/72fd4/72fd4dfc1a3d4a63c6c86fc8b2efebeca5547e49" alt=""
data:image/s3,"s3://crabby-images/7f783/7f7830f368d5040331a838ffe7509e1c9d2ef03f" alt=""
成功!
- 取得連結
- X
- 以電子郵件傳送
- 其他應用程式
留言
張貼留言