美文网首页
第三方登录Facebook篇

第三方登录Facebook篇

作者: 善良的老农 | 来源:发表于2021-11-29 17:51 被阅读0次

    参考Facebook官方链接

     接入登陆功能


    已创建项目,则选择没有则创建 如图添加登录功能

    在facebook创建应用后,要在应用信息页面的 “控制面板” 选择你要开通的功能,并且在左边 “产品” 列表看到你开通的功能的才继续接入。

    接下来开始接入:

    在您的项目中,打开your_app>Gradle Scripts>build.gradle (Project),确保下列存储库都添加到buildscript { repositories {}}中:

    jcenter()

    在您的项目中,打开your_app>Gradle Scripts>build.gradle (Module: app)并将下列执行语句添加到dependencies{}部分,以便依赖于最新版的 Facebook 登录 SDK:

    implementation 'com.facebook.android:facebook-login:[4,5)'

    构建项目。

    4.编辑您的资源和清单

    为您的 Facebook 应用编号以及启用 Chrome 自定义选项卡所需的编号创建字符串。另外,请将FacebookActivity添加到您的 Android 清单文件中。

    (1).  打开您的/app/res/values/strings.xml文件。

    (2).  添加如下所示的代码:

    <string name="facebook_app_id">应用ID</string><string name="fb_login_protocol_scheme">应用ID</string>

    (3). 打开/app/manifest/AndroidManifest.xml文件。

    (4).  在application元素后添加以下uses-permission元素:

    <uses-permissionandroid:name="android.permission.INTERNET"/>

    (5).在application元素中添加以下meta-data元素、一个针对 Facebook 的 activity 元素以及一个针对 Chrome 自定义选项卡的 activity 元素和意向筛选条件:

    <meta-dataandroid:name="com.facebook.sdk.ApplicationId"android:value="@string/facebook_app_id"/><activityandroid:name="com.facebook.FacebookActivity"android:configChanges="keyboard|keyboardHidden|screenLayout|screenSize|orientation"android:label="@string/app_name"/><activityandroid:name="com.facebook.CustomTabActivity"android:exported="true"><intent-filter><actionandroid:name="android.intent.action.VIEW"/><categoryandroid:name="android.intent.category.DEFAULT"/><categoryandroid:name="android.intent.category.BROWSABLE"/><dataandroid:scheme="@string/fb_login_protocol_scheme"/></intent-filter></activity>

    5.

    添加包名和主类

    填入你的包名和发起facebook登陆请求的Activity。

    6.为应用提供开发和发布密钥散列

    为确保您的应用与 Facebook 之间互动的真实性,您必须先向我们提供您的开发环境下的 Android 密钥散列。如果您的应用已经发布,则还应该同时提供发布密钥散列。

    生成开发密钥散列

    每个 Android 开发环境都将会有一个唯一的开发密钥散列。Mac 操作系统

    要生成开发密钥散列,请打开一个终端窗口,运行以下命令:

    keytool-exportcert-aliasandroiddebugkey-keystore~/.android/debug.keystore|openssl sha1-binary|openssl base64

    Windows

    您需要以下各项:

    Java 开发包中的密钥和证书管理工具 (keytool)

    Google Code Archive的 Windows 版openssl-for-windowsopenssl 函数库

    要生成开发密钥散列,请在 Java SDK 文件夹的命令提示符中运行以下命令:

    keytool -exportcert -alias androiddebugkey -keystore "C:\Users\USERNAME\.android\debug.keystore" | "PATH_TO_OPENSSL_LIBRARY\bin\openssl" sha1 -binary | "PATH_TO_OPENSSL_LIBRARY\bin\openssl" base64

    此命令将针对您的开发环境生成一个包含 28 个字符的唯一密钥散列。将其复制粘贴到下面的字段中。对于参与应用开发的每个人的开发环境,您必须分别提供开发密钥散列。

    生成发布密钥散列

    Android 应用必须先使用发布密钥进行电子签名,然后才能上传到商店中。要生成发布密钥散列,请在 Mac 或 Windows 内运行以下命令,并替换您的发布密钥别名和 keystore 路径:

    keytool-exportcert-aliasYOUR_RELEASE_KEY_ALIAS-keystoreYOUR_RELEASE_KEY_PATH|openssl sha1-binary|openssl base64

    这会生成一个包含 28 个字符的字符串,您应将其复制粘贴到下面的字段中。另外,请参阅Android 文档,了解有关应用签名的信息。

    最终添加成功的样子

    输入上面生成的密钥散列。

    如果觉得上面的密钥生成方法麻烦,我这提供一个简单的:

    public void getkey(Activity activity) {

    try {

    PackageInfo info = activity.getPackageManager().getPackageInfo("com.example.myproject", PackageManager.GET_SIGNATURES);

            for (Signature sign : info.signatures) {

    MessageDigest md = MessageDigest.getInstance("SHA");

                md.update(sign.toByteArray());

                editText.setText(Base64.encodeToString(md.digest(), Base64.DEFAULT));

                Log.e("KeyHash:", Base64.encodeToString(md.digest(), Base64.DEFAULT));

            }

    }catch (PackageManager.NameNotFoundException e) {

    e.printStackTrace();

            Log.e("KeyHash:", "error " + e.toString());

        }catch (NoSuchAlgorithmException e) {

    e.printStackTrace();

            Log.e("KeyHash:", "error " + e.toString());

        }

    }

     亲测可用。

    7.

    我们产品是单点登录

    8.添加 Facebook“登录”按钮

    向应用添加“Facebook 登录”按钮的最简单方法是从 SDK 添加 LoginButton。LoginButton 是一个界面元素,其中包含 LoginManager 具备的功能。用户点击按钮后,就会以 LoginManager 中设置的权限开始登录。按钮随登录状态变化,并根据用户的身份验证状态显示正确文本。

    要添加 Facebook 登录按钮,请先将其添加到布局 XML 文件中:

    <com.facebook.login.widget.LoginButton    android:id="@+id/login_button"    android:layout_width="wrap_content"    android:layout_height="wrap_content"    android:layout_gravity="center_horizontal"    android:layout_marginTop="30dp"    android:layout_marginBottom="30dp" />

    9.注册回调

    现在调用 CallbackManager.Factory.create,创建 callbackManager,以便处理登录响应。

    callbackManager = CallbackManager.Factory.create();

    如果您将按钮添加到 Fragment(片段),则您还必须更新 activity(活动),以使用此 Fragment。您可以自定义 Login button 的属性,并在 onCreate() 或 onCreateView() 方法中注册一个回调。您可以自定义的属性包括 LoginBehavior、DefaultAudience、ToolTipPopup.Style 以及 LoginButton 的相关权限。例如:

        loginButton = (LoginButton) findViewById(R.id.login_button);    loginButton.setReadPermissions("email");    // If using in a fragment    loginButton.setFragment(this);   

        // Callback registration    loginButton.registerCallback(callbackManager, new FacebookCallback<LoginResult>() {        @Override        public void onSuccess(LoginResult loginResult) {            // App code        }        @Override        public void onCancel() {            // App code        }        @Override        public void onError(FacebookException exception) {            // App code        }    });

    为了响应登录结果,您需要使用 LoginManager 或 LoginButton 注册回调。如果您使用 LoginButton 注册回调,就不需要在登录管理器中注册回调。

    将 LoginManager 回调添加到 activity 或 fragment 的 onCreate() 方法:

        callbackManager = CallbackManager.Factory.create();    LoginManager.getInstance().registerCallback(callbackManager,            new FacebookCallback<LoginResult>() {                @Override                public void onSuccess(LoginResult loginResult) {                    // App code                }                @Override                public void onCancel() {                    // App code                }                @Override                public void onError(FacebookException exception) {                    // App code                  }    });

    如果登录成功,LoginResult 参数将拥有新的 AccessToken 及最新授予或拒绝的权限。

    您不需要 registerCallback 来保证登录成功,可以选择使用下述 AccessTokenTracker 类跟踪当前访问口令的更改。

    最后,在 onActivityResult 方法中调用 callbackManager.onActivityResult,通过 callbackManager 将登录结果传递至 LoginManager。

          @Override    protected void onActivityResult(int requestCode, int resultCode, Intent data) {        callbackManager.onActivityResult(requestCode, resultCode, data);        super.onActivityResult(requestCode, resultCode, data);    }

    您集成到 FacebookSDK 登录或分享功能的所有活动和片段都应将 onActivityResult 转发到 callbackManager。

    10.检查登录状态

    您的应用一次只能登录一个用户,LoginManager 会为该用户设置当前的 AccessToken 和 Profile。FacebookSDK 会将该数据保存在共享首选项中,并在会话开始时设置此数据。您可以通过检查 AccessToken.getCurrentAccessToken() 和 Profile.getCurrentProfile() 来查看用户是否已登录。

    您可以通过 SDK 从缓存或应用书签中(如果应用冷启动)加载 AccessToken.getCurrentAccessToken。您应在 Activity 的 onCreate 方法中检查它的有效性:

    AccessToken accessToken = AccessToken.getCurrentAccessToken();boolean isLoggedIn = accessToken != null && !accessToken.isExpired(); 

    稍后您可以执行实际登录,例如在自定义按钮的 OnClickListener 中:

          LoginManager.getInstance().logInWithReadPermissions(this, Arrays.asList("public_profile"));

    相关文章

      网友评论

          本文标题:第三方登录Facebook篇

          本文链接:https://www.haomeiwen.com/subject/kuylxrtx.html