1、首先在Facebook 开发者平台注册一个账号

https://developers.facebook.com/

开发者后台  https://developers.facebook.com/apps

2、创建账号并且获得 APP ID

图一

图二

图三

图四

图五

3、获取app签名的Key Hashes 值(两种方式)

获取方式:https://blog.csdn.net/zhaoyanjun6/article/details/105344657                            

4、设置应用的基本配置

图一

图二

图三

5、App开始集成 FacebookSDk

5.1 在项目的 build.gradle 添加

compile 'com.facebook.android:facebook-android-sdk:4.10.1'

查看最新的版本 : http://search.maven.org/#search%7Cga%7C1%7Ccom.facebook.android

5.2 在应用的 Application 里面初始化SDK

//facebook登录初始化

      FacebookSdk.sdkInitialize( getApplicationContext() );

5.3 在value文件夹下 strings.xml 中

<!-- facebook 登录 key-->

      <string name="facebook_app_id">1001702146573854</string>

5.4 在 AndroidManifest.xml 中

<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:theme="@android:style/Theme.Translucent.NoTitleBar"
android:label="@string/app_name"
>
</activity>  

5.5 在布局文件中定义登录按钮

 <com.facebook.login.widget.LoginButton
android:id="@+id/facebook_bt"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:text="facebook login"
>
</com.facebook.login.widget.LoginButton>

  

5.6 在代码中实现

 package com.pegasus.map.presentation.ui.activity;
import android.content.Intent;
import android.os.Bundle;
import android.widget.Toast;
import com.facebook.CallbackManager;
import com.facebook.FacebookCallback;
import com.facebook.FacebookException;
import com.facebook.login.LoginResult;
import com.facebook.login.widget.LoginButton;
import com.pegasus.map.R;
import com.pegasus.map.presentation.ui.base.BaseActivity;
import butterknife.Bind;
import butterknife.ButterKnife; /**
* Created by ${zyj} on 2016/3/24.
* 登录
*/ public class LoginLoginActivity extends BaseActivity { @Bind(R.id.facebook_bt)
public LoginButton facebook_bt; private CallbackManager callbackManager ; @Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_login); ButterKnife.bind(this);
callbackManager = CallbackManager.Factory.create() ; init();
} private void init() { facebook_bt.registerCallback(callbackManager, new FacebookCallback<LoginResult>() {
@Override
public void onSuccess(LoginResult loginResult) {
Toast.makeText(LoginLoginActivity.this, "facebook登录成功了", Toast.LENGTH_SHORT).show();
log("facebook登录成功了" + loginResult.getAccessToken());
//获取登录信息
getLoginInfo( loginResult.getAccessToken() ) ;
} @Override
public void onCancel() {
Toast.makeText(LoginLoginActivity.this, "facebook登录取消了", Toast.LENGTH_SHORT).show();
log("facebook登录取消了");
} @Override
public void onError(FacebookException error) {
Toast.makeText(LoginLoginActivity.this, "facebook登录失败了", Toast.LENGTH_SHORT).show();
log("facebook登录失败了");
}
}); } @Override
protected void onActivityResult(int requestCode, int resultCode, Intent data) {
super.onActivityResult(requestCode, resultCode, data); //facebook回调
callbackManager.onActivityResult( requestCode , resultCode ,data ) ;
}
}
 /**
* 获取登录信息
* @param accessToken
*/
public void getLoginInfo( AccessToken accessToken ){
GraphRequest request = GraphRequest.newMeRequest(accessToken, new GraphRequest.GraphJSONObjectCallback() {
@Override
public void onCompleted(JSONObject object, GraphResponse response) {
if (object != null) {
String id = object.optString( "id" ) ; //比如:1565455221565
String name = object.optString( "name" ) ; //比如:Zhang San
String gender = object.optString("gender") ; //性别:比如 male (男) female (女)
String emali = object.optString("email") ; //邮箱:比如:56236545@qq.com //获取用户头像
JSONObject object_pic = object.optJSONObject( "picture" ) ;
JSONObject object_data = object_pic.optJSONObject( "data" ) ;
String photo = object_data.optString( "url" ) ; //获取地域信息
String locale = object.optString( "locale" ) ; //zh_CN 代表中文简体 Toast.makeText( activity , "" + object.toString() , Toast.LENGTH_SHORT).show();
}
}
}) ; Bundle parameters = new Bundle();
parameters.putString("fields", "id,name,link,gender,birthday,email,picture,locale,updated_time,timezone,age_range,first_name,last_name");
request.setParameters(parameters);
request.executeAsync() ;
}

5.7 企业账号需要注意的事项,把发布按钮打开

6、对facebookSDk 进行二次封装

 package com.pegasus.map.presentation.utils;

 import android.app.Activity;
import android.content.DialogInterface;
import android.os.Bundle;
import android.support.v7.app.AlertDialog;
import android.widget.Toast; import com.facebook.AccessToken;
import com.facebook.CallbackManager;
import com.facebook.FacebookCallback;
import com.facebook.FacebookException;
import com.facebook.GraphRequest;
import com.facebook.GraphResponse;
import com.facebook.Profile;
import com.facebook.login.LoginManager;
import com.facebook.login.LoginResult; import org.json.JSONObject; import java.util.Arrays;
import java.util.Collections;
import java.util.List; /**
* Created by ${zyj} on 2016/3/30.
*/
public class FaceBookLogin { private Activity activity ;
private CallbackManager callbackManager ;
private FacebookListener facebookListener ;
private List<String> permissions = Collections.<String>emptyList();
private LoginManager loginManager; public FaceBookLogin( Activity activity ){
this.activity = activity ; //初始化facebook登录服务
callbackManager = CallbackManager.Factory.create() ;
getLoginManager().registerCallback(callbackManager, new FacebookCallback<LoginResult>() {
@Override
public void onSuccess(LoginResult loginResult) {
// login success
AccessToken accessToken = loginResult.getAccessToken();
getLoginInfo(accessToken);
} @Override
public void onCancel() {
//取消登录
} @Override
public void onError(FacebookException error) {
//登录出错
}
}); permissions = Arrays
.asList("email", "user_likes", "user_status", "user_photos", "user_birthday", "public_profile", "user_friends") ;
} /**
* 登录
*/
public void login(){
getLoginManager().logInWithReadPermissions(
activity, permissions);
} /**
* 退出
*/
public void logout(){
String logout = activity.getResources().getString(
com.facebook.R.string.com_facebook_loginview_log_out_action);
String cancel = activity.getResources().getString(
com.facebook.R.string.com_facebook_loginview_cancel_action);
String message;
Profile profile = Profile.getCurrentProfile();
if (profile != null && profile.getName() != null) {
message = String.format(
activity.getResources().getString(
com.facebook.R.string.com_facebook_loginview_logged_in_as),
profile.getName());
} else {
message = activity.getResources().getString(
com.facebook.R.string.com_facebook_loginview_logged_in_using_facebook);
}
AlertDialog.Builder builder = new AlertDialog.Builder(activity);
builder.setMessage(message)
.setCancelable(true)
.setPositiveButton(logout, new DialogInterface.OnClickListener() {
public void onClick(DialogInterface dialog, int which) {
getLoginManager().logOut();
}
})
.setNegativeButton(cancel, null);
builder.create().show();
} /**
* 获取登录信息
* @param accessToken
*/
public void getLoginInfo( AccessToken accessToken ){
GraphRequest request = GraphRequest.newMeRequest(accessToken, new GraphRequest.GraphJSONObjectCallback() {
@Override
public void onCompleted(JSONObject object, GraphResponse response) {
if (object != null) {
String id = object.optString("id"); //比如:1565455221565
String name = object.optString("name"); //比如:Zhang San
String gender = object.optString("gender"); //性别:比如 male (男) female (女)
String emali = object.optString("email"); //邮箱:比如:56236545@qq.com //获取用户头像
JSONObject object_pic = object.optJSONObject("picture");
JSONObject object_data = object_pic.optJSONObject("data");
String photo = object_data.optString("url"); //获取地域信息
String locale = object.optString("locale"); //zh_CN 代表中文简体 Toast.makeText(activity, "" + object.toString(), Toast.LENGTH_SHORT).show();
}
}
}) ; Bundle parameters = new Bundle();
parameters.putString("fields", "id,name,link,gender,birthday,email,picture,locale,updated_time,timezone,age_range,first_name,last_name");
request.setParameters(parameters);
request.executeAsync() ;
} /**
* 获取loginMananger
* @return
*/
private LoginManager getLoginManager() {
if (loginManager == null) {
loginManager = LoginManager.getInstance();
}
return loginManager;
} public CallbackManager getCallbackManager(){
return callbackManager ;
} /**
* 设置登录简体器
* @param facebookListener
*/
public void setFacebookListener( FacebookListener facebookListener ){
this.facebookListener =facebookListener ;
} public interface FacebookListener {
void facebookLoginSuccess();
void facebookLoginFail() ;
} }

在 activity 使用

      //初始化Facebook登录服务
FaceBookLogin faceBookLogin = new FaceBookLogin( this ) ; //登录
faceBookLogin.login(); //退出
faceBookLogin.logout();
 @Override
protected void onActivityResult(int requestCode, int resultCode, Intent data) {
super.onActivityResult(requestCode, resultCode, data); //facebook回调
faceBookLogin.getCallbackManager().onActivityResult(requestCode, resultCode, data); }

最新更新(2020/4/16)

最近有机会又接触到海外项目,刚好要做 facebook 登陆功能,下面我把封装的代码用 Kotlin 实现一遍:

FacebookLoginUtil 工具类
package com.enjoy.literaturemodule.account.login.facebook

import android.app.Activity
import android.content.DialogInterface
import android.os.Bundle
import androidx.appcompat.app.AlertDialog
import com.facebook.*
import com.facebook.AccessToken
import com.facebook.login.LoginManager
import com.facebook.login.LoginResult
import org.json.JSONObject /**
* @author yanjun.zhao
* @time 2020/3/10 2:35 PM
* @desc
*/
class FacebookLoginUtil(private var activity: Activity) { private var loginManager: LoginManager? = null
private val permissions: List<String>
private var callbackManager: CallbackManager? = null init {
//初始化facebook登录服务
callbackManager = CallbackManager.Factory.create()
getLoginManager()?.registerCallback(callbackManager, object : FacebookCallback<LoginResult> {
override fun onSuccess(result: LoginResult?) {
getLoginInfo(result?.accessToken)
} override fun onCancel() {
} override fun onError(error: FacebookException?) {
}
})
permissions = listOf("email", "user_likes", "user_status", "user_photos", "user_birthday", "public_profile", "user_friends");
} /**
* 登陆
*/
fun login() {
getLoginManager().logInWithReadPermissions(activity, permissions)
} /**
* 退出登陆
*/
fun loginOut() {
var logout = activity.resources.getString(com.facebook.R.string.com_facebook_loginview_log_out_action)
var cancel = activity.resources.getString(com.facebook.R.string.com_facebook_loginview_cancel_action)
val message: String
val profile: Profile = Profile.getCurrentProfile()
message = if (profile?.name != null) {
java.lang.String.format(
activity.resources.getString(
R.string.com_facebook_loginview_logged_in_as),
profile.name)
} else {
activity.resources.getString(
R.string.com_facebook_loginview_logged_in_using_facebook)
}
val builder: AlertDialog.Builder = AlertDialog.Builder(activity)
builder.setMessage(message)
.setCancelable(true)
.setPositiveButton(logout, DialogInterface.OnClickListener { dialog, which ->
getLoginManager().logOut()
})
.setNegativeButton(cancel, null)
builder.create().show()
} /**
* 获取登录信息
* @param accessToken
*/
private fun getLoginInfo(accessToken: AccessToken?) {
var request = GraphRequest.newMeRequest(accessToken, object : GraphRequest.GraphJSONObjectCallback {
override fun onCompleted(`object`: JSONObject?, response: GraphResponse?) { `object`?.run {
val id = optString("id") //比如:1565455221565
val name = optString("name") //比如:Zhang San
val gender = optString("gender") //性别:比如 male (男) female (女)
val emali = optString("email") //邮箱:比如:56236545@qq.com
//获取用户头像
val object_pic = optJSONObject("picture")
val object_data = object_pic.optJSONObject("data")
val photo = object_data.optString("url")
//获取地域信息
val locale = optString("locale") //zh_CN 代表中文简体 }
}
})
val parameters = Bundle()
parameters.putString("fields", "id,name,link,gender,birthday,email,picture,locale,updated_time,timezone,age_range,first_name,last_name")
request.parameters = parameters
request.executeAsync()
} fun getCallbackManager(): CallbackManager? {
return callbackManager
} /**
* 获取loginMananger
* @return
*/
private fun getLoginManager(): LoginManager {
if (loginManager == null) {
loginManager = LoginManager.getInstance();
}
return loginManager!!
} companion object { /**
* 是否处在登陆状态
*/
fun isLogin(): Boolean {
val accessToken = AccessToken.getCurrentAccessToken()
val isLoggedIn = accessToken != null && !accessToken.isExpired
return isLogin()
}
}
}

Activity 使用示范

package com.enjoy.literaturemodule.account

import android.app.Activity
import android.content.Intent
import android.os.Bundle
import com.enjoy.literaturemodule.R
import com.enjoy.literaturemodule.account.login.facebook.FacebookLoginUtil
import kotlinx.android.synthetic.main.activity_login.* /**
* 登陆
*/
class LoginActivity : Activity() { private var faceBookUtil: FacebookLoginUtil? = null override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
setContentView(R.layout.activity_login)
faceBookUtil = FacebookLoginUtil(this) facebook_login?.setOnClickListener {
faceBookUtil?.login()
}
} override fun onActivityResult(requestCode: Int, resultCode: Int, data: Intent?) {
//facebook 登陆
//facebook回调
faceBookUtil?.getCallbackManager()?.onActivityResult(requestCode, resultCode, data)
super.onActivityResult(requestCode, resultCode, data)
}
}

Android 应用程序集成FaceBook 登录及二次封装的更多相关文章

  1. Android 应用程序集成Google 登录及二次封装

    谷歌登录API:  https://developers.google.com/identity/sign-in/android/ 1.注册并且登录google网站 https://accounts. ...

  2. android应用集成facebook登录

      之前都是做国内的应用开发,没有用过国外的三方登录,比如谷歌登录.facebok登录,最近参与了一个海外的支付相关的项目,调研了一下谷歌登录和facebook登录,其实调研之后觉得也是很简单的,尤其 ...

  3. 在Android上实现使用Facebook登录(基于Facebook SDK 3.5)

    准备工作: 1.       Facebook帐号,国内开发者需要一个vpn帐号(网页可以浏览,手机可以访问) 2.       使用Facebook的SDK做应用需要一个Key Hashes值. 2 ...

  4. 在Android App中集成Google登录

    技术文章 来源:码农网 发布:2016-09-19 浏览:194 摘要:今天,几乎所有的web和移动app都自带谷歌和Facebook登录,这对app开发者和用户来说是一个非常有用的功能,因为几乎每个 ...

  5. Android 学习笔记之AndBase框架学习(二) 使用封装好的进度框,Toast框,弹出框,确认框...

    PS:渐渐明白,在实验室呆三年都不如在企业呆一年... 学习内容: 1.使用AbActivity内部封装的方法实现进度框,Toast框,弹出框,确认框...   AndBase中AbActivity封 ...

  6. Android 版 Facebook 登录

    Android 版 Facebook SDK 让用户可以通过 Facebook 登录注册您的应用.通过 Facebook 登录您的应用时,用户可以向应用授予权限,以便您可以检索信息或以用户的身份在 F ...

  7. Android平台接入Facebook登录

    官方教程地址: https://developers.facebook.com/docs/android/getting-started 开发环境为Android Studio,官方要求SDK最低版本 ...

  8. 社会化登录分享-Android SDK的二次封装和使用

    本系列文章将第三方的登录分享功能进行二次封装,统一接口调用,简化了接不同平台登录分享的步骤. 0 系列文章 系列一 Android SDK的二次封装和使用 系列二 源码解析 系列三 微信SDK接入 系 ...

  9. 利用本地HTTPS模拟环境为FastAPI框架集成FaceBook社交三方登录

    原文转载自「刘悦的技术博客」https://v3u.cn/a_id_174 提起社交,就不得不说马克·扎克伯格(Mark Zuckerberg)一手创办的社交网络(FaceBook).进入2020年, ...

随机推荐

  1. 手动实现jQuery Tools里面tab功能

    平时开发中用的Javascript类库都是jQuery,用到插件或者第三方类库能从jQuery Tools里面找到,基本不用其他的.当然有时同事喜欢使用jQuery UI里面的插件.并且jQuery ...

  2. 应用程序框架实战三十六:CRUD实战演练介绍

    从本篇开始,本系列将进入实战演练阶段. 前面主要介绍了一些应用程序框架的概念和基类,本来想把所有概念介绍完,再把框架内部实现都讲完了,再进入实战,这样可以让初学者基础牢靠.不过我的精力很有限,文章进度 ...

  3. 使用wireshark抓包分析浏览器无法建立WebSocket连接的问题(server为Alchemy WebSockets组件)

    工作时使用了Websocket技术,在使用的过程中发现,浏览器(Chrome)升级后可能会导致Websocket不可用,更换浏览器后可以正常使用. 近日偶尔一次在本地调试,发现使用相同版本的Chrom ...

  4. EntityFramework 7 Join Count LongCount 奇怪问题

    先吐槽一下,EF7 目前来说,真对的起现在的版本命名:"EntityFramework": "7.0.0-beta1". 这篇博文纪录一下:当 Linq 查询中 ...

  5. [python]CentOS 6下安装Python2.7

    安装方法 如果在CentOS上自己编译安装过python2.7,使用过程中会发现有些标准库没有安装之类的问题. 逛别人博客的时候发现,一个便捷的方法:使用RHSCL的全称是Red Hat Softwa ...

  6. VARCHAR列上的索引

    一年前,我写了在索引的导航结构里,SQL Server如何存储VARCHAR列.我们都知道,在SQL Server里索引(聚集索引,非聚集索引)的键列有最大900byte的大小限制. 假设现在你想捉弄 ...

  7. react入门(1)

    这篇文章也不能算教程咯,就算是自己学习整理的笔记把. 关于react一些相关的简介.优势之类的,随便百度一下一大堆,我就不多说了,可以去官网(http://reactjs.cn/)看一下. 这片主要讲 ...

  8. c#中字段和属性的区别

    在我看来(本人是C#初学者)字段实际上类似一个变量,或者就直接说字段就是一个变量.相应的属性也可以看做是一个变量,只不过多了一些限制而已. using System;using System.Coll ...

  9. 关于SQL Server 安装程序在运行 Windows Installer 文件时遇到错误

    前几日安装sql server2008r2 的时候碰到这个问题: 出现以下错误: SQL Server 安装程序在运行 Windows Installer 文件时遇到错误. Windows Insta ...

  10. Ehcache 缓存使用

    在开发高并发量,高性能的网站应用系统时,缓存Cache起到了非常重要的作用.本文主要介绍EHCache的使用,以及使用EHCache的实践经验. 笔者使用过多种基于Java的开源Cache组件,其中包 ...