所有第三方登录都要先获取第三方应用的Id和秘钥
开发之前,需要前往第三方登录的开发者平台QQ、新浪微博、Github,注册账号并填写信息申请接入,成功后会给你一个ID和秘钥,以后你就通过该ID和秘钥来获取令牌,从而实现第三方登录。申请ID和秘钥时Github不需要审核,很简单,而QQ和新浪微博需要审核,稍微麻烦一点。
获得ID和秘钥后需要在setting中进行设置
以钉钉登录为例:关键点就是获取到钉钉的凭证appid,然后将appid跟我们的用户模型联系起来。
这是钉钉的开发者文档:我们应先做好准备工作,可以借鉴以下文档,完成前期准备工作http://wiki.connect.qq.com/准备工作_oauth2-0事件订阅 - 钉钉开放平台钉钉会向应用推送订阅的事件,例如部门变更、签到通知、打卡通知等。通过订阅这些事件,可以更好地与钉钉集成。你只需告诉钉钉当某个事件发生时,钉钉需要推送消息到哪个URL,钉钉会以HTTPhttps://open.dingtalk.com/document/org/push-eventshttp://wiki.connect.qq.com/准备工作_oauth2-0 第三方登录都有其相应的开发者文档。
我们先用一张流程图来简单了解一下钉钉第三方登录都需要做什么,为我们写代码,带来一些思路
图画的不是太好,但是基本还是可以帮我们理解一下第三方登录流程,以及梳理第三方登录的思路。
我们先把前端写一下,前端生成二维码
前端
<button @click="dingding">钉钉登录</button>
// 钉钉登录
dingding: function () {
var appid = "dingoajf8cqgyemqarekhr";
var redirect_uri = 'http://127.0.0.1:8080/' + "dingding";
var url =
"https://oapi.