前端接入Facebook/Google/Apple登录

本文基于JS本地接入,通过三方登录授权获取openid和token,通过服务端接口进行账号体系注册

1.Google登录

Google开发文档

网上大部分都是使用Google的的按钮样式,自定义按钮样式有限。所以我这里使用js API进行授权登录

后台配置:

Google后台是支持localhost进行测试的,但是需要再后台添加授权来源;找到后台的已获授权的JavaScript来源里填写,如何网页的端口不是80开头需要填写具体的端口号;然后等待一段时间就可以测试了

<script src="https://accounts.google.com/gsi/client?hl=en_US" async defer></script>
<button  onclick="signIn()">Sigin in with Google</button>

 const client = google.accounts.oauth2.initCodeClient({
            client_id: '客户端ID',
            ux_mode: 'popup',
            scope: 'https://www.googleapis.com/auth/calendar.readonly',
            callback: (response) => {
                console.log('google auth:', res);
            }
  })
function signIn(){
    //请求code,服务端通过code拿到想要的用户信息
    client.requestCode();
}

2.Facebook登录

Facebook开发文档

后台配置

在Facebook后台创建web应用,进入web设置页面.

设置,打开启动网页登录使用JavaScript SDK登录

填写JavaScript SDK允许使用的网域,可以填写localhost但必须是https,保存之后就可以facebook登陆了

引入facebookSDK

<script async defer crossorigin="anonymous" src="https://connect.facebook.net/zh_CN/sdk.js#xfbml=1&version=v20.0&appId=facebookclientID&autoLogAppEvents=1"></script>
//使用javascript API进行调用。如果要切换用户请在facebook网站进行切换
window.FB.login((response) => {
    if (response.authResponse) {
        const thridLoginInfo = { openid: response.authResponse.userID, token: response.authResponse.accessToken, login_pfkey: 'facebook' }
       
    } else {
        console.log('User cancelled login or did not fully authorize.');
    }
}, { scope: 'email,public_profile', return_scopes: true });

3.Apple登录

Apple开发文档

苹果登录首先要去苹果后台注册一个ClientId,然后才可以登录

1.在Apple官网进入证书,点击Identifiers加号创建一个标识

2.选择Services IDs,填写一个ID,保存

3.保存之后返回ServicesIDs列表点击刚才创建的ServicesID,勾选Sign In with Apple并配置重定向地址,等配置

4.之后就可以进行代码编写了

苹果登录按钮样式自定义范围不是很大,具体可以参考文档

<div id="appleid-signin" 
     class="signin-button" 
     data-mode="left-align" 
     data-type="sign in" 
     data-color="black"
     data-border="false" 
     data-border-radius="15" 
     data-width="250" 
     data-height="40" 
     data-logo-size="medium"
     data-logo-position="5">
</div>

API调用

AppleID.auth.init({
    clientId : '[CLIENT_ID]', //苹果后台注册的客户端ID
    scope : 'email', //访问权限 
    redirectURI : '[REDIRECT_URI]', //登录成后的重定向地址
    state : '[STATE]',  //透传字段 
    usePopup : true  //Popup方式打开
});
//监听登陆回调
document.addEventListener("AppleIDSignInOnSuccess", function(data){
  //解析token的用户信息,也可把token给服务端让服务去解析
  function getAppleDataFromToken(token) {
          var base64Url = token.split(".")[1];
          var base64 = base64Url.replace(/-/g, "+").replace(/_/g, "/");
          var jsonPayload = decodeURIComponent(atob(base64).split("").map(function (c) {
              return "%" + ("00" + c.charCodeAt(0).toString(16)).slice(-2)
          }).join(""));
          return JSON.parse(jsonPayload)
    }
   const appleUserData = getAppleDataFromToken(data.detail.authorization.id_token);
   //用户ID:   appleUserData.sub, 
   //用户token: data.detail.authorization.id_token, login_pfkey: 'appstore' }
};
document.addEventListener("AppleIDSignInOnFailure", this.appleSignInOnFailure)
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,185评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,445评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 157,684评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,564评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,681评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,874评论 1 290
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,025评论 3 408
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,761评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,217评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,545评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,694评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,351评论 4 332
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,988评论 3 315
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,778评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,007评论 1 266
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,427评论 2 360
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,580评论 2 349

推荐阅读更多精彩内容