第三方登录流程

##一、OAuth 2.0简介
为了简化网站和应用的注册登录开发以及留住大量”较懒“的用户,第三方登录横空出世,比如QQ登录,微信登录,微博登录等等;
第三方登录也叫做第三方授权,相应的规范是OAuth 2.0;每家提供第三方登录的大型互联网公司都有具体实现,原理一致,大体过程一致,细节有较小差别。
在这里插入图片描述
##二、qq第三方登录流程
###1、首先要在qq互联网上注册并审核通过个人开发者账号或者企业开发者账号,这里我注册的个人开发者

但是具体的应用这里创建不了,因为需要的备案号之类的资料提供不了。

###2、应用创建之后会得到appId和appKey,然后获取Authorization Code
请求地址:
PC网站:https://graph.qq.com/oauth2.0/authorize
请求方法:
GET
请求参数:
请求参数请包含如下内容:

参数 是否必须 含义
response_type 必须 授权类型,此值固定为“code”。
client_id 必须 申请QQ登录成功后,分配给应用的appid。
redirect_uri 必须 成功授权后的回调地址,必须是注册appid时填写的主域名下的地址,建议设置为网站首页或网站的用户中心。注意需要将
state 必须 client端的状态值。用于第三方应用防止CSRF攻击,成功授权后回调时会原样带回。请务必严格按照流程检查用户与state参数状态的绑定。
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Flask提供了多种第三方登录的方式,其中比较常用的是使用OAuth 2.0和OpenID Connect协议进行认证。 下面是使用Flask-Dance库实现GitHub第三方登录流程: 1. 安装Flask-Dance库和GitHub的OAuth应用程序 ``` pip install Flask-Dance ``` 在GitHub上创建OAuth应用程序,并记录下Client ID和Client Secret。 2. 创建Flask应用程序并配置Flask-Dance ```python from flask import Flask, redirect, url_for from flask_dance.contrib.github import make_github_blueprint, github app = Flask(__name__) app.secret_key = "secretkey" github_blueprint = make_github_blueprint(client_id="client_id", client_secret="client_secret") app.register_blueprint(github_blueprint, url_prefix="/login") @app.route("/") def index(): if not github.authorized: return redirect(url_for("github.login")) resp = github.get("/user") assert resp.ok return "You are @{login} on GitHub".format(login=resp.json()["login"]) if __name__ == "__main__": app.run() ``` 在上述代码中,我们先创建了一个Flask应用程序。然后,我们通过`make_github_blueprint`函数创建了一个名为`github`的蓝图,并将其注册到应用程序中。在注册蓝图时,我们指定了`url_prefix`参数为`/login`,这意味着我们将使用`/login/github`来访问GitHub登录页面。 接下来,我们定义了一个路由`/`,当用户成功登录并授权后,将会显示该页面。在该路由函数中,我们使用Flask-Dance提供的`github`对象来获取用户的GitHub信息,并将其显示在页面上。 3. 运行Flask应用程序并访问GitHub第三方登录页面 运行上述代码,然后在浏览器中访问`http://localhost:5000`。如果用户未授权,则会重定向到GitHub登录页面。在成功登录并授权后,将会重定向回我们的应用程序,并显示GitHub用户信息。 以上就是使用Flask-Dance实现GitHub第三方登录流程。其他第三方登录流程类似,只需要更改蓝图和OAuth应用程序的信息即可。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值