如何使用 Kotlin 整合 Facebook?


此示例演示瞭如何使用 Kotlin 整合 Facebook。

步驟 1 - 在 Android Studio 中建立一個新專案,轉到檔案 ⇒ 新建專案,並填寫所有必需的詳細資訊以建立新專案。

步驟 2 - 在您的專案中,開啟 your_app | Gradle Scripts | build.gradle (Module: app) 並將以下編譯語句新增到 dependencies{} 部分以編譯 SDK 的最新版本 -

implementation 'com.facebook.android:facebook-login:5.15.3'

步驟 3 - 新增您的包名和預設活動類名,如下所示,單擊儲存並繼續。

步驟 4 - 建立一個金鑰雜湊。根據您的作業系統,您需要複製程式碼 → 開啟 Android Studio Rarr;開啟終端並貼上程式碼,如下所示。

輸入程式碼後,系統會提示您輸入金鑰庫密碼。輸入“android”,它會為您提供金鑰雜湊。複製金鑰雜湊並貼上到 facebook 開發者網站的金鑰雜湊部分,如下所示。

單擊儲存並繼續。

步驟 5 - 只需單擊下一步。

步驟 6 - 開啟 res/strings.xml 並新增以下程式碼

<string name="facebook_app_id">511795909507190</string>
<string name="fb_login_protocol_scheme">fb511795909507190</string>

步驟 7 - 將以下程式碼新增到 res/layout/activity_main.xml。

<?xml version="1.0" encoding="utf-8"?>
<com.facebook.login.widget.LoginButton
xmlns:android="http://schemas.android.com/apk/res/android"
   android:id="@+id/loginButton"
   android:layout_width="wrap_content"
   android:layout_height="wrap_content"
   android:layout_gravity="center_horizontal"
   android:layout_marginTop="30dp"
   android:layout_marginBottom="30dp" />

步驟 8 - 將以下程式碼新增到 MainActivity.kt

import android.content.Intent
import android.os.Bundle
import android.util.Log
import androidx.appcompat.app.AppCompatActivity
import com.facebook.AccessToken
import com.facebook.CallbackManager
import com.facebook.FacebookCallback
import com.facebook.FacebookException
import com.facebook.login.LoginManager
import com.facebook.login.LoginResult
import com.facebook.login.widget.LoginButton
@Suppress("DEPRECATION")
class MainActivity : AppCompatActivity() {
   lateinit var callbackManager: CallbackManager
   private val EMAIL = "email"
   override fun onCreate(savedInstanceState: Bundle?) {
      super.onCreate(savedInstanceState)
      setContentView(R.layout.activity_main)
      val loginButton = findViewById<LoginButton>(R.id.loginButton)
      loginButton.setOnClickListener {
         loginButton.setReadPermissions(listOf(EMAIL))
         callbackManager = CallbackManager.Factory.create()
         // If you are using in a fragment, call loginButton.setFragment(this);
         // Callback registration
         // If you are using in a fragment, call loginButton.setFragment(this);
         // Callback registration
         loginButton.registerCallback(callbackManager, object : FacebookCallback<LoginResult?> {
            override fun onSuccess(loginResult: LoginResult?) {
               Log.d("MainActivity", "Facebook token: " + loginResult!!.accessToken.token)
               startActivity(
                  Intent(
                     applicationContext,
                     AuthenticatedActivity::class.java
                  )
               )// App code
            }
            override fun onCancel() { // App code
         }
         override fun onError(exception: FacebookException) { // App code
      }
   })
   callbackManager = CallbackManager.Factory.create()
   LoginManager.getInstance().registerCallback(callbackManager,
   object : FacebookCallback<LoginResult?> {
      override fun onSuccess(loginResult: LoginResult?) { // App code
   }
   override fun onCancel() { // App code
   }
   override fun onError(exception: FacebookException) { // App code
   }
   val accessToken = AccessToken.getCurrentAccessToken()
   accessToken != null && !accessToken.isExpired
   }
   override fun onActivityResult(
      requestCode: Int,
      resultCode: Int,
      data: Intent?
   ) {
      callbackManager.onActivityResult(requestCode, resultCode, data)
      super.onActivityResult(requestCode, resultCode, data)
      callbackManager.onActivityResult(requestCode, resultCode, data)
   }
}

步驟 9 - 建立一個名為 MyApplication.kt 的類,該類擴充套件 Application 並新增以下內容 -

import android.app.Application
import com.facebook.FacebookSdk
import com.facebook.appevents.AppEventsLogger
@Suppress("DEPRECATION")
class MyApplication : Application() {
   override fun onCreate() {
      super.onCreate()
      FacebookSdk.sdkInitialize(applicationContext)
      AppEventsLogger.activateApp(this)
   }
}

步驟 10 - 為登出建立一個新的活動,並新增以下程式碼 -

LogoutActivty.kt

import android.os.Bundle
import android.view.View
import android.widget.Button
import androidx.appcompat.app.AppCompatActivity
import com.facebook.AccessToken
import com.facebook.GraphRequest
import com.facebook.HttpMethod
import com.facebook.login.LoginManager
class LogoutActivity : AppCompatActivity() {
   override fun onCreate(savedInstanceState: Bundle?) {
      super.onCreate(savedInstanceState)
      setContentView(R.layout.logout_activity)
      val btnLogout = findViewById<Button>(R.id.btnLogout)
      btnLogout.setOnClickListener(View.OnClickListener {
         // Logout
         if (AccessToken.getCurrentAccessToken() != null) {
            GraphRequest(
               AccessToken.getCurrentAccessToken(), "/me/permissions/", null, HttpMethod.DELETE,
               GraphRequest.Callback {
                  AccessToken.setCurrentAccessToken(null)
                  LoginManager.getInstance().logOut()
                  finish()
               }
            ).executeAsync()
         }
      })
   }
}

logout_activity.xml

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
   android:layout_width="match_parent"
   android:layout_height="match_parent">
   <LinearLayout
      android:layout_width="match_parent"
      android:layout_height="wrap_content"
      android:layout_centerInParent="true"
      android:orientation="vertical">
   <TextView
      android:layout_width="wrap_content"
      android:layout_height="wrap_content"
      android:layout_gravity="center_horizontal"
      android:text="Login success!" />
   <Button
      android:id="@+id/btnLogout"
      android:layout_width="match_parent"
      android:layout_height="wrap_content"
      android:layout_margin="20dp"
      android:background="#3c66c4"
      android:text="Logout"
      android:textAllCaps="false"
      android:textColor="@android:color/white" />
   </LinearLayout>
</RelativeLayout>

步驟 11 - 將以下程式碼新增到 androidManifest.xml

(注意 - 您需要在應用程式內新增元資料)

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
   package="app.com.q35">
   <uses-permission android:name="android.permission.INTERNET" />
   <application
      android:allowBackup="true"
      android:icon="@mipmap/ic_launcher"
      android:label="@string/app_name"
      android:roundIcon="@mipmap/ic_launcher_round"
      android:supportsRtl="true"
      android:theme="@style/AppTheme">
      <activity android:name=".MainActivity">
         <intent-filter>
            <action android:name="android.intent.action.MAIN" />
            <category android:name="android.intent.category.LAUNCHER" />
         </intent-filter>
      </activity>
      <meta-data
         android:name="com.facebook.sdk.ApplicationId"
         android:value="@string/facebook_app_id" />
      <activity
         android:name="com.facebook.FacebookActivity"
            android:configChanges="keyboard|keyboardHidden|screenLayout|screenSize|orientation"
            android:label="@string/app_name" />
      <activity
          android:name="com.facebook.CustomTabActivity" android:exported="true">
         <intent-filter>
            <action android:name="android.intent.action.VIEW" />
            <category android:name="android.intent.category.DEFAULT" />
            <category android:name="android.intent.category.BROWSABLE" />
            <data android:scheme="@string/fb_login_protocol_scheme" />
         </intent-filter>
      </activity>
      <activity android:name=".LogoutActivity" />
   </application>
</manifest>

如有任何疑問,請訪問 https://developers.facebook.com/

讓我們嘗試執行您的應用程式。我假設您已將您的實際 Android 移動裝置連線到您的計算機。要從 android studio 執行應用程式,請開啟您的一個專案活動檔案,然後單擊工具欄中的執行  圖示。選擇您的移動裝置作為選項,然後檢查您的移動裝置,它將顯示您的預設螢幕

單擊登入後,它將轉到登入螢幕,您需要輸入您的使用者名稱和密碼。由於我之前已登入,因此它要求繼續。單擊登入,如果身份驗證成功,它將顯示登出活動。

點選 此處 下載專案程式碼。

更新於: 2020年4月21日

2K+ 瀏覽量

開啟你的 職業生涯

透過完成課程獲得認證

開始
廣告

© . All rights reserved.