Python|Flask框架实现QQ账号登录

简介: Python|Flask框架实现QQ账号登录

前期准备

因为注册QQ互联需要已备案的网站,所以需要准备一个已备案的网站与域名。

首先访问QQ互联平台https://connect.qq.com/,注册成为开发者;

然后创建一个网站应用,等审核成功后会得到一个APP ID与APP KEY,后面会使用到。

开发流程

图1 准备网站应用

1 前端放置登录按钮

在网站找一个合适的位置放置登录按钮(建议放置在首页、登录页以及注册页)。登录按钮图标在QQ互联平台下载,上面提供了多种样式。效果如下:

图2 登陆页

具体HTMl代码如下:

<a 

href="https://graph.qq.com/oauth2.0/authorize?response_type=code&client_id=YOURAPPID&redirect_uri=URL">

<img src="{{url_for('static',filename'base/images/Connect_logo_7.png')}}"></a>

其中a标签中 client_id 是最开始申请的APPID,redirect_uri是申请网站填写的网站回调域。

这样点开QQ登录按钮,就能跳转到QQ登录的界面:

图3 转跳后页面

2 获取Access Toke

当登录成功后,会跳转到刚刚所填写的回调地址。并且url后面会跟上Authorization Code此Code在10分钟内过期)。接着通过Code值去获取Access Token(Access Token是应用在调用OpenAPI访问和修改用户数据时必须传入的参数)。

为了获取Access Token需要请求:

https://graph.qq.com/oauth2.0/token,方式为GET,请求参数包括以下:

参数

是否必须

含义

grant_type

必须

值为“authorization_code”。

client_id

必须

申请QQ登录成功后,分配给网站的appid。

client_secret

必须

申请QQ登录成功后,分配给网站的appkey。

code

必须

上一步返回的authorization code

redirect_uri

必须

与上面一步中传入的redirect_uri保持一致。

如果成功返回,就可以得到Access Token。这一步具体代码如下:

@home.route('/mycb')

def mycb():

    data = request.args.to_dict()

    code = data.get('code') #获取authorization code

    url = 'https://graph.qq.com/oauth2.0/token'

body={'grant_type': 'authorization_code', 'client_id': '101860781','client_secret':'0f5a014e13e7d35fbcca51ecc2ff6745','code':code,'redirect_uri':'https://yujl.top/mycb'}

#body为上面所说的请求参数

    response = requests.get(url, params=body) #发送GET请求

    token = response.text 得到返回包

    token_url = '?' + token

    requests.session().close() #关闭请求

    return redirect('/token' + token_url)

由于返回回来的包格式为:

access_token=61897CE***************D444F968BD2A&expires_in=77**000&refresh_token=0018693**************6009D9C2EFBE

这样不能直接转换为json格式,所以将这个包作为参数然后转发到/token,以此来得到json格式的token。

@home.route('/token')

def token():

    data = request.args.to_dict() #得到access_token、expires_in、refresh_token

3 通过access_token来获取open_id

接着需要通过access_token来获取open_id(openid是此网站上唯一对应用户身份的标识,网站可将此ID进行存储便于用户下次登录时辨识其身份)。

请求地址为https://graph.qq.com/oauth2.0/me,方法还是GET,参数就是上面获取到的access_token。具体方法为:

def get_openid(data): data为token得到的数据包

    url = 'https://graph.qq.com/oauth2.0/me'

    body = {'access_token': data.get('access_token')}

    response = requests.get(url, params=body)

    open_id = json.loads(response.text[10:-4])

    open_id = open_id.get('openid')

    requests.session().close()

    return open_id

4 调用OpenAPI

得到open_id就可以调用OpenAPI了,API列表如下:

图4 API列表

接下来以get_user_info 为例:

还是以GET方式请求:

https://graph.qq.com/user/get_user_info,

需要的参数有access_token、oauth_consumer_key(APP ID)、openid。代码示例:

def get_user_info(data, open_id):

    url = 'https://graph.qq.com/user/get_user_info'

    body={'access_token':data.get('access_token'), 'oauth_consumer_key': '101860781', 'openid': open_id}

    response = requests.get(url, params=body)

    user_info = response.json()

    requests.session().close()

    return user_info

返回的参数说明:

图5 参数说明

5 保存用户数据

到这一步,基本就完成了。接着就是根据自己的需要,可以在user界面展示昵称和头像,和选择存进数据库了。选择将open_id作为用户的唯一标识符存进数据库,这样用户在后面登录的时候可以得到上次保存的信息。以下是这部分代码:

@home.route('/token')

def token():

    data = request.args.to_dict()

    open_id = get_openid(data)

    user_info = get_user_info(data, open_id)

uuid_count=User.query.filter_by(uuid=open_id).count()

#查询openid是否存在。

if uuid_count == 1:

#如果存在就根据openid查到用户信息,并添加到session空间里。

        name = User.query.filter_by(uuid=open_id).first()

        session['home'] = name.name

        return redirect('/user')

else:

#如果不存在,也就是第一次登录,给一个默认的密码(经过hash加密)

        password = generate_password_hash('123456')

        hash_name = str(hash(random.randint(1000,9999)))

        name = user_info.get('nickname') + hash_name

#因为我的网站是不允许重名的,所以在qq的昵称后面加上一个随机数。

        user = User(

            name=name, #添加了随机数的用户名

            uuid=open_id, #唯一标识符

            pwd = password, #密码

            face=user_info.get('figureurl_1') #头像

        )#将相关信息存进数据库

        db.session.add(user)

        db.session.commit()

        session['home'] = name #将用户名添加到session空间中。

        return redirect('/user') # 重定向到user界面。

 

目录
相关文章
|
10天前
|
Python
python3之flask快速入门教程Demo
python3之flask快速入门教程Demo
31 6
|
10天前
|
开发框架 数据库 开发者
Web开发新境界:用Python玩转Django和Flask!
【6月更文挑战第12天】Python的Web开发框架Django和Flask各有千秋。Django是全能型框架,适合快速开发大型应用,提供ORM、模板引擎、URL路由和后台管理等全面功能。Flask则轻量级且灵活,适用于小型到中型应用,以其简单易用、高度可扩展和灵活路由著称。两者结合使用,能应对各种Web开发需求。
|
23天前
|
缓存 自然语言处理 数据库
构建高效Python Web应用:异步编程与Tornado框架
【5月更文挑战第30天】在追求高性能Web应用开发的时代,异步编程已成为提升响应速度和处理并发请求的关键手段。本文将深入探讨Python世界中的异步编程技术,特别是Tornado框架如何利用非阻塞I/O和事件循环机制来优化Web服务的性能。我们将剖析Tornado的核心组件,并通过实例演示如何构建一个高效的Web服务。
|
4天前
|
关系型数据库 MySQL 数据库
如何使用Python的Flask框架来构建一个简单的Web应用
如何使用Python的Flask框架来构建一个简单的Web应用
11 0
|
19天前
|
存储 数据管理 测试技术
构建Python构建自动化测试框架(原理与实践)
当谈到软件质量保证时,自动化测试是一个不可或缺的步骤。Python作为一种简单易学的编程语言,具有丰富的测试框架和库,使得构建自动化测试框架变得相对简单。本文将介绍如何使用Python构建自动化测试框架,包括选择合适的测试框架、编写测试用例、执行测试和生成报告等方面。
构建Python构建自动化测试框架(原理与实践)
|
2天前
|
缓存 前端开发 API
了解python中几个主流的网络框架
【6月更文挑战第21天】探索Python Web几个流行框架,了解各框架特性以适应不同场景需求。
14 1
|
5天前
|
存储 数据挖掘 索引
Python streamlit框架开发数据分析网站并免费部署
使用Python的Streamlit框架,开发了一个在线数据分析工具,替代Excel查看设备温度CSV数据。通过pandas读取数据,matplotlib绘制图表。程序处理CSV,提取所需列,计算最大最小平均值,用户可多选查看特定数据。[GitHub](https://github.com/yigedaigua/MGHB)上有完整代码,应用已部署至Streamlit Cloud。
|
11天前
|
分布式计算 负载均衡 并行计算
Python 分布式计算框架 PP (Parallel Python):集群模式下的实践探索
该文介绍了使用Parallel Python (PP) 在两台物理机上构建分布式计算集群的经验。PP是一个轻量级框架,旨在简化Python代码在多处理器系统和集群中的并行执行。文中通过设置子节点的IP、端口和密钥启动PP服务器,并在主节点创建PP实例进行负载均衡。实验使用官方的质数和计算示例,显示PP在集群模式下能有效利用多台机器的多核CPU,实现计算效率的显著提升。未来,作者计划进一步研究PP在更复杂任务和大规模集群中的应用潜力。
|
12天前
|
数据采集 存储 中间件
Scrapy,作为一款强大的Python网络爬虫框架,凭借其高效、灵活、易扩展的特性,深受开发者的喜爱
【6月更文挑战第10天】Scrapy是Python的高效爬虫框架,以其异步处理、多线程及中间件机制提升爬取效率。它提供丰富组件和API,支持灵活的数据抓取、清洗、存储,可扩展到各种数据库。通过自定义组件,Scrapy能适应动态网页和应对反爬策略,同时与数据分析库集成进行复杂分析。但需注意遵守法律法规和道德规范,以合法合规的方式进行爬虫开发。随着技术发展,Scrapy在数据收集领域将持续发挥关键作用。
56 4
|
12天前
|
IDE 测试技术 持续交付
Python作为一种简洁、易读且功能强大的编程语言,其自动化测试和单元测试框架的丰富性和易用性为开发者提供了极大的便利
【6月更文挑战第10天】本文探讨了Python自动化测试与单元测试框架在提升代码质量和效率中的作用。Selenium、Appium和pytest是常用的自动化测试框架,分别支持Web和移动应用的测试。unittest是Python的标准单元测试框架,提供断言方法和测试组织结构。通过制定测试计划、编写高质量测试用例、持续集成与测试、以及有效利用测试报告,开发者能提高代码质量和开发效率。
27 1