分类: Web开发
2017-01-03 18:38:59
本文主要讲解 集成 第三方社交账号登录
主要是因为目前互联网的网站数量太多,如果在各个站点都注册一个账号 用户非常不容易记住每个账号的用户名和密码,并且非常难保证每个账号的密码足够安全
而目前流行的社交网站 基本上每个用户都有账号,如果通过这类社交网站登录 就能得到如下几点好处
用户不用再注册其他账号
用户只能维护社交账户足够安全就行了,使用此社交账号登录的就是安全的了
微信
新浪微博
人人网
百度
Github
国内这些比较大的社交公司 都有专门的开放平台,有经验的开发者可以看开放平台是可以实现了,本人主要实现三个社交登录
新浪微博登录
QQ登录
Github登录
进入 申请网页应用,微博应用可以先申请等上线之后再提交审核
进入 ,登录之后 进入 应用管理,QQ应用需要先审核通过之后才可以使用(PS: 我被驳回了4次才通过,很多项和备案信息相关的)
进入 登录之后 进入 设置页面
CREATE TABLE `user` ( `uid` int(11) unsigned NOT NULL AUTO_INCREMENT COMMENT '用户uid', `nickname` varchar(20) NOT NULL DEFAULT '' COMMENT '用户昵称', `unique_name` varchar(60) NOT NULL DEFAULT '' COMMENT '唯一标识', `avatar` varchar(500) NOT NULL DEFAULT '' COMMENT '用户头像', `mobile` varchar(11) NOT NULL DEFAULT '' COMMENT '用户手机号码', `updated_time` timestamp NOT NULL DEFAULT '0000-00-00 00:00:00' COMMENT '最后一次更新时间', `created_time` timestamp NOT NULL DEFAULT '0000-00-00 00:00:00' COMMENT '插入时间', PRIMARY KEY (`uid`), UNIQUE KEY `idx_name` (`unique_name`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='用户表'; CREATE TABLE `oauth_token` ( `id` int(11) unsigned NOT NULL AUTO_INCREMENT, `client_type` varchar(20) NOT NULL DEFAULT '' COMMENT '客户端来源类型', `token` varchar(100) NOT NULL DEFAULT '', `note` varchar(1000) NOT NULL DEFAULT '' COMMENT '备注', `valid_to` timestamp NOT NULL DEFAULT '0000-00-00 00:00:00' COMMENT '有效期截止日期', `updated_time` timestamp NOT NULL DEFAULT '0000-00-00 00:00:00' COMMENT '最后一次更新时间', `createdt_time` timestamp NOT NULL DEFAULT '0000-00-00 00:00:00' COMMENT '插入时间', PRIMARY KEY (`id`), KEY `client_type_token` (`client_type`,`token`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='oauth token 表'; CREATE TABLE `oauth_bind` ( `id` int(11) unsigned NOT NULL AUTO_INCREMENT, `uid` int(11) NOT NULL DEFAULT '0' COMMENT '用户uid', `client_type` varchar(20) NOT NULL DEFAULT '' COMMENT '客户端', `openid` varchar(80) NOT NULL DEFAULT '' COMMENT '第三方id', `extra` text NOT NULL COMMENT '额外字段', `created_time` timestamp NOT NULL DEFAULT '0000-00-00 00:00:00' COMMENT '插入时间', PRIMARY KEY (`id`), KEY `idx_client_type_opend_id` (`client_type`,`openid`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='第三方登录绑定关系';
相关代码文件:
ClientService.php 统一第三方登录方法,应用程序的方法入口 GithubService.php Github第三方登录相关方法 QqService.php QQ第三方登录相关方法 WeiboService.php 微博第三方登录相关方法
地址: ,感兴趣大家可以自行前往试试
获取用户信息的相关逻辑,放入队列处理,因为获取信息还是比较慢的
原文地址:标签: