最近公司要求做海外的第三方登录;目前只做了Facebook和Twitter;国内百度到的信息太少VPN FQ百度+Google了很久终于弄好了。但是做第三方登录基本上都有个特点就是引入必须的js,设置appkey/appId;然后调用登录方法即可得到用户信息。

首先Facebook:

1).在Facebook开发者平台注册自己的application;然后得到appid和应用密钥;

2).接下来就异步引用Facebook的sdk.js并调用初始化方法;

 1 window.fbAsyncInit = function() {
2  FB.init({
3  appId :'appid',
4  xfbml : true,
5  version : 'v2.6' //facebook登录版本
6  });
7 };
8 //异步引入Facebook sdk.js
9(function(d, s, id){
10  var js, fjs = d.getElementsByTagName(s)[0];
11  if (d.getElementById(id)) {return;}
12  js = d.createElement(s); js.id = id;
13  js.src = "//connect.facebook.net/en_US/sdk.js";
14  fjs.parentNode.insertBefore(js, fjs);
15}(document, 'script', 'facebook-jssdk'));

3).在html中引入Facebook按钮标签

1 <fb:login-button scope="public_profile,email"   onlogin="checkLoginState();"></fb:login-button> <!-- 点击登录时触发checkLoginState(),此方法自定义 -->

4).定义checkLoginState方法登录并获取token并传给后台;

 1         var fbToken;
2 function checkLoginState(){
3 FB.getLoginStatus(function(response) {
4 statusChangeCallback(response);
5 });
6 }
7 function statusChangeCallback(response) {
8 if (response.status === 'connected') { //登陆状态已连接
9 fbToken = response.authResponse.accessToken;
10 getUserInfo();
11 } else if (response.status === 'not_authorized') { //未经授权
12 console.log('facebook未经授权');
13 } else {
14 console.log('不是登陆到Facebook;不知道是否授权');
15 }
16 }
17 //获取用户信息
18 function getUserInfo() {
19 FB.api('/me', function(response) {
20 //response.id / response.name
21 console.log('Successful login for: ' + response.name);
22 //把用户token信息交给后台
23 self.location= '/home/login.fbLogin.do?accessToken='+fbToken;
24 });
25 }

至此;Facebook第三方登录前端就完成了!

接下来是Twitter;

1).还是先到Twitter开发者平台注册自己的应用;注册成功会得到appkey和API Secret。(在https://apps.twitter.com/上注册自己的app/web)

2).在https://auth-server.herokuapp.com/登录自己的Twitter账号;然后新建一个项目把在Twitter开发者平台注册得到的appkey和API Secret设置到这个项目中,注意一个appkey和API Secret只能设置一个域名,reference描述(举个例子如你的项目叫百度,那就写个百度),domain就是项目域名(主域名);grant_url可不填,我是填了的(https://api.twitter.com/oauth/access_token)。(最近不少博友问点击的时候Twitter登录框闪退。如果没在这个网址注册你的项目的话会有点击Twitter闪退的现象,请务必配置)

另外:还有一个问题会导致闪退,那就是在https://apps.twitter.com注册自己的app的时候一定要把Callback URL填上。不然也会出现闪退。我的Callback URL填的跟一级域名一样

如下配置:

3).在页面引入Twitter所需的js。其中要特别注意的是要引入 http://adodson.com/hello.js/dist/hello.all.js(这个是重点)

 1 window.twttr = (function(d, s, id) {
2 var js, fjs = d.getElementsByTagName(s)[0],
3 t = window.twttr || {};
4 if (d.getElementById(id)) return t;
5 js = d.createElement(s);
6 js.id = id;
7 js.src = "https://platform.twitter.com/widgets.js";
8 fjs.parentNode.insertBefore(js, fjs);
9
10 t._e = [];
11 t.ready = function(f) {
12 t._e.push(f);
13 };
14
15 return t;
16 }(document, "script", "twitter-wjs"));

4).在页面上声明一个Twitter登录的button并监听登录事件。

1 <button class="twBtn" onclick = "login_twitter('twitter')" ></button>

5).初始化Twitter登录并定义login_twitter登录方法。

 1     
        var log = console.log;
        hello.init({
 2                 'twitter' : appkey
3 },
4 {
5 // redirect_uri:'/', //代理后的重定向路径,可不填
6 oauth_proxy: 'https://auth-server.herokuapp.com/proxy' //这里使用默认的代理
7 });
8 function login_twitter(network){ //登录方法,并将twitter 作为参数传入
9 // Twitter instance
10 var twitter = hello(network);
11 // Login
12 twitter.login().then( function(r){
13 // Get Profile
14 return twitter.api('/me');
15 }, log ) .then( function(p){
16 console.log("Connected to "+ network+" as " + p.name);
19 var res = JSON.stringify(p);//因为得不到token,但是这步已经得到用户所有信息,所以将用户信息转成JSON字符串给后台
21 self.location= '/home/login.twLogin.do?result='+res;
22 }, log );
23 }

完成Twitter第三方登录前端代码。

以上就是Facebook和Twitter的第三方登录;给大家一个参考,有不对的地方希望大家指正。谢谢!

详细介绍请查看全文:https://cnblogs.com/qianzf/
原文博客的链接地址:https://cnblogs.com/qzf/

网站如何集成Facebook和Twitter第三方登录的更多相关文章

  1. 分享前端Facebook及Twitter第三方登录

    最近公司要求做海外的第三方登录:目前只做了Facebook和Twitter;国内百度到的信息太少VPN FQ百度+Google了很久终于弄好了.但是做第三方登录基本上都有个特点就是引入必须的js,设置 ...

  2. java网站如何集成facebook第三方登录

    第一次接触Facebook第三方登录,可能有些地方做的并不全面,只是尝试着做了一个小demo,因为国内接入Facebook的项目并不多,并且多数都是Android或iOS的实现,所以资料也特别少,在此 ...

  3. 国外流行的共享网站实现:facebook,twitter,google+1,tumblr等待

    近期需要做相关的国外几个站点共享,本来我以为它会和weibo.在同样的烦恼空间,什么appkey啦,apptoken啦.api啦.结果非常意外的发现并非如此恼火. Twitter分享: https:/ ...

  4. 集成Facebook和Twitter的Model动画-b

    这个动画.  感谢大神分享 JPPopPresentAnimation.gif 要实现这个功能分两步走:第一步,先实现这个动画.第二步,0行代码集成到项目.也就是,你不用改原有项目的任何代码,只要把写 ...

  5. Android Facebook和Twitter登录和分享完整版

    最近公司的软件需要改国际版,需要Facebook和Twitter的登录和分享. 本人先用Umeng的第三方社会化分享实现了该功能,但是后来一想问题来了,经过查证.Umeng只在中国和美国有服务器,那也 ...

  6. 第三方登录开发-Facebook

    这次这个项目要分别可以使用新浪微博,qq互联以及Facebook和Twitter授权登录 facebook目前只支持oauth2技术,个人理解其工作流程是当用户想访问当前网站,却不想注册账号,此时当前 ...

  7. 用 Flask 来写个轻博客 (23) — 应用 OAuth 来实现 Facebook 第三方登录

    目录 目录 前文列表 扩展阅读 第三方登录流程 OAuth 应用 OAuth 实现 Facebook 第三方登录 实现效果 前文列表 用 Flask 来写个轻博客 (1) - 创建项目 用 Flask ...

  8. Android记录16-友盟第三方登录、分享实现

    Android开发记录16-友盟第三方登录.分享实现 2014年博客之星,投票地址username=wwj_748#content" style="font-family: Kai ...

  9. GitHub OAuth 第三方登录示例教程

    这组 OAuth 系列教程,第一篇介绍了基本概念,第二篇介绍了获取令牌的四种方式,今天演示一个实例,如何通过 OAuth 获取 API 数据. 很多网站登录时,允许使用第三方网站的身份,这称为&quo ...

随机推荐

  1. Java 成员变量和局部变量

    1.成员变量 在类中定义,用来描述对象将要有什么. 2.局部变量 在类的方法中定义,在方法中临时保存数据. 成员变量和局部变量的区别 作用域不同: 局部变量的作用域仅限于定义它的方法 成员变量的作用域 ...

  2. asterisk配置SIP服务器

    服务器asterisk我们安装完以后,需要在windows(就是自己的本机)上在安装一个客户端xlite,直接下载安装就行,安装完以后,我们就需要自己手动配置一下sip服务器了. 下面给大家讲一下怎么 ...

  3. var与Javascript变量隐式声明

    在JavaScript中,var用来声明变量,但是这个语法并不严格要求,很多时修改,我们可以直接使用一个变量而不用var声明它.var x = "XX"; y ="xxx ...

  4. cocos2dx 3.6版本播放动画

    IDE: VS2013 版本:cocos2dx 3.3.6 语言:c++ 11 3.x版本改动与2.x版本相比改动很大,几个比较明显的点就是所有带cc的前缀没有了,然后一些获取类型的函数名称加了get ...

  5. 面试宝典:Java面试中最高频的那20%知识点!

    Java目前已经不仅仅是一门开发语言,而是一整套生态体系. 作为一个Java程序员,既是幸运的,也是不幸的.幸运的是我们有很多轮子可以拿过来用,不幸的是我们有太多的轮子需要学习. 但是,无论是日常工作 ...

  6. Python 小知识点(6)--静态方法、类方法、属性方法

    (1)静态方法-->-@staticmethod装饰类中方法 只是名义上归类管理, 实际上在静态方法里访问不了类或实例中的任何属性 class Dog(object): def __init__ ...

  7. 1、linux软件包管理

    linux软件包管理分为两种:RPM包管理和源码包管理,其中RPM包管理又有两种方式:①RPM命令管理,②YUM在线命令管理. RPM包依赖关系: 1.树形依赖 2.环形依赖 (用一条命令同时装来解决 ...

  8. 基于 DirectX11 的 MMDViewer 04-渲染目标视图和多视口

    上篇文章给出了一个简单并且可以运行的渲染框架,接下来将介绍框架中的渲染管线构成. 1.创建渲染管线 在你创建完一个窗口后,接着便要创建渲染管线,使用的函数是 D3D11CreateDeviceAndS ...

  9. inl文件介绍

    inl文件是内联函数的源文件.内联函数通常在C++头文件中实现,但是当C++头文件中内联函数过多的情况下,我们想使头文件看起来简洁点,能不能像普通函数那样将内联函数声明和函数定义放在头文件和实现文件中 ...

  10. python---webbrowser模块的使用,用非系统默认浏览器打开

    webbrowser模块常用的方法有: webbrowser.open(url, new=0, autoraise=True) 在系统的默认浏览器中访问url地址,如果new=0,url会在同一个浏览 ...