网站添加第三方登陆(PHP版)

news/2024/5/19 11:25:32/文章来源:https://blog.csdn.net/weixin_30338497/article/details/95169416

  这两周正在写毕业设计,我做的是一个问答网站。先介绍一下这个网站:这是一个关于大学生在线问答的网站,类似知乎和百度知道,不过功能没有人家多,毕竟这个网站我一个人在做。网站部署在阿里云,网站包括API,Web,IOS,三大模块,现在没有找到人帮忙写安卓,唉...  网站API已经写完了,Web端正在完善开发中,毕业答辩之前会吧基本功能上线,小伙伴们可以访问看看增加人气,不过没有写完,并且看着不咋好看,因为没人写前端,我又不擅长写页面所以有点低端。域名是:http://www.olas.cn

  上面说的一点题外话,今天要说的是一个大家比较熟悉的东西:第三方登录,因为我的这个毕业设计要用到,所以就顺便加了一下,第三方登陆还是很有用的,这个是现在应用级网站的必备,现在的用户一般都不会去主动去你的注册,一般都是通过第三方的社交账号去登陆,这样省得以后去记密码,而且也比较安全,所以添加第三方登录还是比较好的。下面我结合这个网站的添加过程写点东西。

  第三方登陆,顾名思义:用其他媒体的账号登陆一些网站,现在比较流行的第三方账号一般是:QQ,微博,微信。其他的平台也有,比如:人人,百度贴吧等,感觉这几个没有前面那三个出名,也没有前面那三个用的多,所以今天就说当前最为常用的微博和QQ的登陆方法。

微博登陆

  先说使用新浪微博账号登陆我的网站,微博登陆我理解是有两种:一种是通过前台JS调用不涉及后端的代码就可以实现登陆的功能,另一种是通过SDK进行自己写页面和弹出确认框,自己处理逻辑,下面我会将这两种方法都写一下(其实也不算是两种,只是大体上称为前端和后端 - SDK不一样嘛):

第一种:

  1、先登陆微博的开放平台:http://open.weibo.com,在我的应用中添加自己的网站或者是应用,网站的话域名必须是备案过的域名,不备案的域名禁止添加。我添加是 "答疑之家",等待审核,审通过添加成功之后,点击应用进去之后会看到左边的导航里面有个导航:部署微链接 ->微博登陆 ->微博登陆详细介绍里面就是微博登陆涉及到的文档的添加的步骤。

2.放置登陆按钮,逻辑大致如下:

通过WBML方式

 1 <!--没有回调函数的登录按钮-->                 
 2 <wb:login-button type="3,2" ></wb:login-button>
 3  
 4 <!--有回调函数的登录按钮-->      
 5 <wb:login-button type="3,2" onlogin="login" onlogout="logout" ></wb:login-button>
 6 
 7 // 如需添加回调函数,请在wbml标签中添加onlogin="login" onlogout="logout",并定义login和logout函数。
 8 function login(o) {
 9     alert(o.screen_name)
10 }
11  
12 function logout() {
13     alert('logout');
14 }

通过Js的方式:

 1 <div id="wb_connect_btn" ></div>
 2 
 3 WB2.anyWhere(function (W) {
 4     W.widget.connectButton({
 5         id: "wb_connect_btn",
 6         type: '3,2',
 7         callback: {
 8             login: function (o) { //登录后的回调函数
 9                 alert("login: " + o.screen_name)
10             },
11             logout: function () { //退出后的回调函数
12                 alert('logout');
13             }
14         }
15     });
16 });

添加必要的Js文件:

在HTML标签中增加XML命名空间

1 <html xmlns:wb="http://open.weibo.com/wb">

在HEAD头中引入WB.JS

1 <script src="http://tjs.sjs.sinajs.cn/open/api/js/wb.js?appkey=4121744546" type="text/javascript" charset="utf-8"></script>

在需要部署登录按钮的位置粘贴WBML代码

1 <wb:login-button type="3,2" onlogin="login" onlogout="logout">登录按钮</wb:login-button>

这样就可以,点击按钮就可以通过回调的方式吧用户授权后的信息拿到,比如头像昵称等。

第二种:通过PHP-SDK的方式

这种感觉符合我的需要,可以直接在PHP端处理登陆后的逻辑,前端可以写自己想要的授权打开方式,所以我改用的这一种,首先你需要看一下文档:http://open.weibo.com/wiki/%E6%8E%88%E6%9D%83%E6%9C%BA%E5%88%B6

1:下载PHP-SDK开发包(http://open.weibo.com/wiki/SDK),借助于sdk能让你减少好多不必考虑的东西,所以下载文档还是很有必要的,不过牛逼的你可以袭击写调用方式,毕竟那个文档写的也不咋滴,因为他的代码风格并不是按照PHP PSR(http://www.kancloud.cn/thinkphp/php-fig-psr/3140)规范去写的,感觉很不专业,毕竟是让别人看的东西,规范是很重要的,至少不会挨那么多骂,哈哈!题外话啊!下面看看他的代码,你就该想吐槽了。。。。(换行方式,缩进,if 规范.. 不能忍)

值得注意的是你要记住自己的app id 与key,然后在sdk中换成自己的id

2:前端open登陆授权页面,我是直接通过打开窗口的方式:

1 function oauthLogin() {
2      var A = window.open("http://***/public/tencentopen.html", "TencentLogin", "width=755, height=550,left=300px,top=60px,menubar=0,scrollbars=1,resizable=1,status=1,titlebar=0,toolbar=0,location=1");
3 }

请求地址的处理逻辑:

 1     /**
 2      * 微博打开登陆认证页面
 3      * code:5000004
 4      * time:2016.4.28
 5      */
 6     public function weiboopen()
 7     {
 8         include_once('weiboOauth/config.php' );
 9         include_once('weiboOauth/saetv2.ex.class.php');
10 
11         $weiboObj = new \SaeTOAuthV2(WB_AKEY, WB_SKEY );
12         $code_url = $weiboObj->getAuthorizeURL(WB_CALLBACK_URL);
13 
14         header("Location:" . $code_url);
15     }

3:用户点击微博登陆后的认证返回逻辑:

    /*** 执行微博认证* code:5000005* time:2016.4.28*/public function weibooauth(){include_once('weiboOauth/config.php' );include_once('weiboOauth/saetv2.ex.class.php' );$weiboObj = new \SaeTOAuthV2(WB_AKEY, WB_SKEY);if (isset($_REQUEST['code'])) {$keys = array();$keys['code'] = $_REQUEST['code'];$keys['redirect_uri'] = WB_CALLBACK_URL;try {$token = $weiboObj->getAccessToken('code', $keys) ;} catch (OAuthException $e) {}}$succ['code'] = '100';$succ['message'] = '授权成功';$erro['code'] = '101';$erro['message'] = '授权失败';if(empty($token)) {$msg = $erro;} else {$saeObj = new \SaeTClientV2(WB_AKEY, WB_SKEY, $token['access_token']);$user_info = $saeObj->show_user_by_id($token['uid']);$ret = $this->oauthLogin($user_info, 'weibo');//授权失败if(empty($ret)) {$msg = $erro;} else {session('olas_access_token', $token['access_token']);$msg = $succ;}}$this->assign('msg', $msg);$this->display('oauth');}

4:授权成功以后:

  成功以后,你会把用户的信息写入到数据库,微博登陆会返回用户的昵称,头像信息(各个版本大小的头像),用户的性别等等,还有非常用户的用户uid,这个非常重要的,下次登陆会检查这个UID是不是通过微博登陆过。这个和腾讯的不一样,腾讯的不反回UID而是一个openid,不过性质是一样的,待会我会介绍。

之后返回打开窗口的状态码,刷新父页面进行跳转。

 1 $(document).ready(function(){
 2       if($.trim($("#code").val()) == '100') {
 3              $('#bodys').html("<div>授权成功,正在跳转 . . .</div>");
 4              setTimeout("changewindows();", 800);
 5       } else {
 6               $('#bodys').html("<div style='color:red;'>授权失败,请重试!</div>");
 7       }
 8 });
 9 function changewindows(){
10       window.opener.location.href = 'http://**';
11       window.close();
12 }

    可以了通过SDK中SaeTClientV2中的show_user_by_id就可以得到用户的信息了。你还可以看到那个Sae***因为这个PHP版本是SAE部门维护的,所以只SAE开头的。步骤挺简单的,大家可以认证阅读他的开发文档,反复调试应该不成问题。我看SDK是对微博开发文档的封装:OAuth2/authorize, OAuth2/access_token, OAuth2/get_token_info,OAuth2/revokeoauth2,OAuth2/get_oauth2_token

如果你在接入中有什么问题你可以直接联系我

QQ登陆

  使用QQ登陆也是很常见的,毕竟使用QQ的人多啊!使用QQ就必须按照人家的规范来,不然人家不给授权啊!下面是步骤:

1:和微博一样,首先要申请使用QQ互联,网址:http://connect.qq.com/manage/index 。首先创建应用,审核通过,不通过也可以使用,不过有限制,好像只能使用你自己的账号登陆,如下图:

 

2:一旦通过审核以后你就可以添加和修改自己网站的一些登陆信息,点击 应用基本信息,这里要特别注意回调地址,因为一旦写错不能进行授权认证,所以回调地址要特别的注意,我在接入的时候就是一直报错。还有一个要注意的是添加协作者,这个可以用作测试,很有用的。下面是我自己的网站添加的信息,大家可以瞅瞅,不过关键信息我已经抹去了,隐私嘛。

3:上面的进行完之后,你就可以下载sdk了(http://wiki.connect.qq.com/sdk%E4%B8%8B%E8%BD%BD),我下的是PHP-sdk,下载后把他放在根目录就可以了。然后本地访问配置(主要是配置自己的应用信息),它上面有一个例子,直接可以调用的那种

然后直接js打开授权页,页面地址请求到后台的方法:

 1     /**
 2      * qq打开登陆认证页面
 3      * code:5000006
 4      * time:2016.4.24
 5      */
 6  public function tencentopen()
 7  {
 8      include_once("tencentOauth/qqConnectAPI.php");
 9      $qc = new \QC();
10      $qc->qq_login();
11  }

授权成功以后要再次初始化那个sdk类:感觉这是他的BUG,必须拿上一次登陆返回的acs和open_id去初始化QC重新得到用户的信息。

1  //申请开发$openid
2  $obj = new \QC();
3  $acs = $obj->qq_callback();
4  $openid = $obj->get_openid();
5 
6  //重新赋值,得到用户信息
7  $qc = new \QC($acs, $openid);
8  $user_info = $qc->get_user_info();

完整的代码如下:

 1     /**
 2      * qq登陆认证逻辑
 3      * code:5000007
 4      * time:2016.4.24
 5      */
 6     public function oauth()
 7     {
 8         include_once("tencentOauth/qqConnectAPI.php");
 9 
10         //申请开发$openid
11         $obj = new \QC();
12         $acs = $obj->qq_callback();
13         $openid = $obj->get_openid();
14 
15         //重新赋值,得到用户信息
16         $qc = new \QC($acs, $openid);
17         $user_info = $qc->get_user_info();
18 
19         $succ['code'] = '100';
20         $succ['message'] = '授权成功';
21 
22         $erro['code'] = '101';
23         $erro['message'] = '授权失败';
24 
25         $msg = [];
26         if(empty($user_info)) {
27             $msg = $erro;
28         } else {
29             $user_info['openid'] = $openid;
30             $user_info['appid'] = C('QQ_APPID');
31             $ret = $this->oauthLogin($user_info, 'tencent');
32             
33             //授权失败
34             if(empty($ret)) {
35                 $msg = $erro;
36             } else {
37                 $msg = $succ;
38             }
39         }
40 
41         $this->assign('msg', $msg);
42         $this->display('oauth');
43     }

这里要注意QQ和微博返回用户的ID是不一样的,微博返回的就是用户在微博的真实id,但是QQ不是。他返回的是qq号对应的一个open_Id,感觉腾讯有点扯淡,这直接导致,你无法得到登陆者的QQ号,有点悲哀,只得到一个和QQ号一一对应的open_id,也算不错了,哎!

好了,到这里基本上把微博和QQ的登陆说完了,期间或遇到各种的问题,比如回调地址失败,登陆之后刷新父页面跳转等等,设计到各种的用户体验。

如果大家在添加的时候遇到解决不了的问题可以Q我,我会的我一定给你说,大家共同提高嘛,另外上面说的不对的您可以通过评论告诉我,共同进步嘛。

注意:
1、本博客同步更新到我的个人网站:http://www.zhaoyafei.cn
2、本文属原创内容,为了尊重他人劳动,转载请注明本文地址:
http://www.cnblogs.com/zyf-zhaoyafei/p/5449776.html

 

转载于:https://www.cnblogs.com/zyf-zhaoyafei/p/5449776.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.luyixian.cn/news_show_761951.aspx

如若内容造成侵权/违法违规/事实不符,请联系dt猫网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

php动态网址可以做seo么,动态URL是什么意思?动态URL怎么做

我们经常会听到动态url&#xff0c;很多小白会不太明白&#xff1a;什么是动态URL呢&#xff1f;其实动态URL意味着网页很难被搜索引擎检索到&#xff0c;对于SEO是非常不利的。因此我们需要了解动态URL怎样做能利于SEO。德州SEO七宝总结了以下几点供大家参考&#xff1a;一、动…

asp网站显示 remote host time out

当用户访问网站的时候&#xff0c;显示如下所示信息&#xff1a; 出现这个问题&#xff0c;一般都是用户的浏览器设置了代理&#xff0c;把代理取消就好了&#xff01;

最新30个优秀的旅行网站设计作品欣赏

您可能还喜欢 12个优秀的 HTML5 网站设计案例欣赏30个漂亮的个人作品集网页设计欣赏分享35个非常漂亮的单页网站设计欣赏45个优秀的国外电子商务网站设计欣赏33个非常优秀的网站底部设计案例欣赏旅游网站的页面通常设计得很宽&#xff0c;而且搭配非常有吸引力的图片&#xff0…

作为网站的唯一入口,控制权限,保证网站安全:SpringCloud_Zuul

为什么要学习网关&#xff1f; 答&#xff1a;作为网站的唯一入口&#xff0c;控制权限&#xff0c;保证网站安全 功能&#xff1a;控制权限&#xff08;鉴权&#xff09;、分发请求&#xff08;动态路由&#xff09; 前言&#xff1a;来模拟一个需要用网关的场景 使用Spri…

进行网站设计之母版页

建立站点地图&#xff1a;web.sitemap 创建模板页面:Template.master 下面的代码为Template.master文件定义了标准的HTML元标记和页头。 页头&#xff1a;放一些DIV容器&#xff0c;一个用于菜单链接&#xff0c;一个用于登录框&#xff0c;另一个用于选择主题(一个包含了可选主…

50个极佳的企业网站案例

目前&#xff0c;大多数企业转向Web开发&#xff0c;无论是广告还是开发公司.. 在这个阶段&#xff0c;网页设计师和开发人员发挥了重要作用。 现在&#xff0c; 我们为您带来了50个极佳的企业网站案例&#xff0c;希望能给您带来灵感&#xff0c;在同一个项目或者在未来的网站…

把http网站改为Https网站

腾讯云申请完证书后添加到服务器的方法&#xff1a; https://www.qcloud.com/document/product/400/4143#2.-nginx.E8.AF.81.E4.B9.A6.E9.83.A8.E7.BD.B2申请SSL证书的常见网站有&#xff1a; https://letsencrypt.org/ https://www.startssl.com/ &#xff08;免费&#xff0…

判断是否是爬虫在访问网站

实现代码如下&#xff1a; 转载于:https://www.cnblogs.com/lovebing/p/7742451.html

整理的一些个人觉得不错的国外【图形学】技术论坛和个人网站,以后还会陆续更新...

官网&#xff1a; http://developer.nvidia.com/node/76 http://msdn.microsoft.com/en-us/library/ee663274(vvs.85) http://www.computer.org/portal/web/computingnow/cga http://developer.amd.com/Pages/default.aspx http://www.spacesimulator.net/index.php?phome htt…

做网站SEO优化,这些网络引流方法,你应该知道

对于网站SEO优化来说&#xff0c;网站流量的重要性不言而喻&#xff01;国内的站长平台工具通过用网站流量来衡量一个网站的权重&#xff0c;当你的网站流量很高的时候&#xff0c;同时会影响你网站的权重&#xff0c;进而影响你网站SEO优化排名。所以说流量对于一个网站的意义…

一个有趣的创客网站分享

http://mc.dfrobot.com.cn/portal.php 转载于:https://www.cnblogs.com/vectors07/p/7976494.html

学用MVC4做网站一:修改密码1.3

一用户 1.1用户注册 1.2用户登录 1.3修改密码 修改密码会用到一个UserChangePassword 模型类&#xff0c;先添加UserChangePassword类 /// <summary>/// 用户修改密码模型/// </summary>[NotMapped]public class UserChangePassword{/// <summary>/// 原密码…

如何快速增加百度相关域提升网站权重

早上在论坛seo版块&#xff0c;发现有人问为什么domain&#xff1a;域名后在结果里&#xff0c;怎么会出现网站本身的页面呢?如图&#xff1a; 这让我联想我们在查询网站数据的时候&#xff0c;总会出现如图下面显示&#xff0c;百度反链多少&#xff0c;点击链接就是domain&a…

优化杭州某著名电子商务网站高并发千万级大型数据库经验之- 内存性能

好久没写博客了&#xff0c;一方面是日常工作繁忙&#xff0c;另外一方面是想更多的时间陪陪家里人&#xff0c;享受春天的美好时光&#xff0c;同时还在写一本《程序员&#xff0c;你伤不起》的一本书要由人民邮电出版社出版&#xff1b;我的性格可能也跟大多数程序员类似吧&a…

方维系统,在tip.htm和inc\u\u_menu.htm调用账号绑定状态,已绑定的可链接到该用户在对应网站的地址...

方维系统&#xff0c;在tip.htm和inc\u\u_menu.htm调用账号绑定状态&#xff0c;已绑定的可链接到该用户在对应网站的地址 在tip.htm和inc\u\u_menu.htm调用账号绑定状态&#xff0c;已绑定的可链接到该用户在对应网站的地址 实现类似这样的效果 举例&#xff1a;u_menu.htm&am…

思维导图形式带你读完《大型网站技术架构》上

最近跟着视频做的一个网站用到了soa架构&#xff0c;nginx反向代理&#xff0c;redis集群&#xff0c;dubbo等等优化网站性能的技术。所以决定看一下《大型网站技术架构》这本书&#xff0c;这本书真心感觉不错&#xff0c;里面没有什么代码和晦涩难懂的知识&#xff0c;一般人…

礼品代发网站源码_礼品快递代发——如何挑选靠谱的礼品代发网站?

电商老人都知道&#xff0c;只有礼品单以及拍A发B才能提供最真实的物流信息。但卖家自己快递礼品的话&#xff0c;除了需要快递成本&#xff0c;还有采购成本、仓储成本、人工打包费用、快件包装费用等&#xff0c;极端条件下甚至会产生快件破损丢失的情况&#xff0c;综合成本…

微软网站打不开_更换空间影响网站优化?这样做比原先排名更靠前!

1马上就是清明小长假了&#xff0c;然后是五一小长假plus&#xff0c;再接下来就是端午小长假...接踵而至的各种小长假期间&#xff0c;我们要考虑竞价推广投放问题(这个问题&#xff0c;老牛之前有跟大家讨论过&#xff0c;点此爬楼查看)。然而网站的竞价广告提前设置好了&…

python 判断 网站是否是动态_Python语法速览与实战清单,不知道大家学的怎么样了?...

基础语法Python 是一门高阶、动态类型的多范式编程语言&#xff1b;定义 Python 文件的时候我们往往会先声明文件编码方式:继续给大家分享我的学习地址&#xff0c;我也不想多说了&#xff0c;有需要的就进来吧&#xff01;让我来带大家一起学习&#xff01;# 指定脚本调用方式…

网站克隆工具_Kali Linux工具篇十三:网站克隆技巧Httrack使用技巧

本公众号所有分享&#xff0c;仅做学习交流&#xff0c;切勿用于任何不法用途&#xff01;一、HTTrack是什么&#xff1f;HTTrack 是一个免费并易于使用的线下浏览器工具&#xff0c;全称是 HTTrack Website Copier for Windows&#xff0c;它能够让你从互联网上下载指定的网站…