如何设计 QQ、微信等第三方账号登陆 ?(附数据库结构)-程序员宅基地

技术标签: python  java  jwt  数据库  redis  

这里的多账户区别于系统级别的,我们讲的多账户系统是指,在我们互联网应用当中,我们的应用会使用多个第三方账号进行登录,比如现在常用的APP:网易、微信、QQ等等。

内容

通过这一篇文章:

可以学到:多用户下面的技术方案细节,以及相应的表设计,流程设计。

不可以学到:与其他文章一样,我这里不会有具体代码实现细节,方案做的对,代码咋写都不会太烂。

架构演进

创业初期

归结为创业初期是因为这个时候用户量比较少,甚至还没有接入上面所说的其他第三方的账户系统,只是自建的体系就可以满足,自建体系的话,目前常用的有

用户名密码注册登陆

这种方式在很多初期网站建设会使用,先注册,再进行登录,在老一点的cms中都能找到这个影子。

流程图:

流程说明:

前端将用户名、密码发送到服务器,服务器进行常规的判断,判断用户名、密码长度是否满足,用户名是否重复等条件,条件不通过直接返回对应错误码给到前端,这里密码字段,为了防止传输过程中被截胡,建议加密再上传,我们的传输密码默认都是会进行一个md5加密,然后记录到数据库再进行一层加密,就算是脱库也没事,密码不要明文存储。

校验通过后,就将用户名密码写入数据库,并进行后面积分发放等操作,这里不展开。

现在进行登录,前端将用户名,密码发送给到服务端,服务端首先会校验登录次数是否超过设置的阈值,如果超过只能继续等待被关小黑屋。

如果未超过继续登录逻辑,判断用户名、密码是否正确,不正确密码则进行阈值的判断,如果超过则关小黑屋,记住小黑屋必须设置过期时间,要不然就会永久关上了,这个可以用redis的过期来做。

登录成功后进行后续的一切后置逻辑,比如加积分。。。等操作。

手机号注册登陆

流程图:

流程说明:

首先输入手机号,然后发送到服务端,服务端将手机号记录在我们数据库中,然后生成随机验证码,并将手机号和验证码绑定到一个redis里面,然后记录过期时间,这个过期时间一般是10分钟左右,这就是我们一般手机验证码的有效期。

手机接收到手机短信后,那么就在界面填写验证码发送服务端,服务端收到验证码后就会在redis里面查询到这个手机号对应的验证码,失败就返回错误码。

成功后就进行登录操作。

这里看起来没有明确的注册登录操作,其实在发送手机号码就可以认为是一个常规的注册,然后后面的验证码输入就是一个登陆操作,

问: 那我要密码咋办?

答: 在后续产品里面增加一个 手机号码密码补录的功能 即可,这也是现在很常规的手法,但是现在移动互联网大爆炸时代,密码已经显得不是那么重要了,反正我从来记不住密码,如果手机号码能操作的app,绝对不用密码来操作。

数据库设计

表结构 :

自增id用户名密码手机号错误次数

1user17fef6171469e80d32c0559f88b377245134567890120

2user27fef6171469e80d32c0559f88b377245134567890130

说明 :

这里只是单纯说明需要用到的数据,没有扩展具体场景,这个表结构能够满足上面两个方案的设计。

引入第三方账户方案

这里是以QQ-SDK的登录逻辑, 我们先来一波时序图

说明:

客户端自己调起登录的界面,进行输入用户名、密码,这里的是第三方的用户名,密码,登录成功后,会返回access_token openid expire_in,这过程会使用到oauth2.0,不过在sdk里面进行内置回调获取了,后面我们会说明我们自身实现的oauth2.0

客户端拿到access_token、openid、login_type(qq、wechat...)请求应用服务器,应用服务器拿到这些数据后就会根据对应的login_type去对应的用户中心进行access_token和openid进行校验。校验不通过则返回对应错误码

校验通过后就会判断本地是否有这个login_type和openid是否存在,不存在则进行获取远程的用户名、头像等基础信息来作为本地基础数据,并且返回code值

如果已经存在,那就是进行登录操作,返回code值。

客户端拿到code值后进行token值的换取,这个完全遵照oauth2.0的协议来走的,后续每次请求必须带上token,token值在服务端的时间比较久,因为我们想要做的是那种永不下线的操作,所以每次请求我们都将token过期时间进行累加。

数据库设计

根据部分小伙伴的的建议,我这里做一下数据库的整理:

用户基础表(users)

字段备注

user_id用户id

token用户登陆的token

expire_intoken过期时间

try_times登录失败次数

用户验证关联表(user_auth_rel)

字段备注

id自增id

user_id用户id

auth_id验证表id

auth_type验证类型(local、third)

本地用户表(user_local_auth)

字段备注

auth_id认证id,自增id

user_name用户唯一标识

password用户密码

mobile用户手机

第三方用户表(user_third_auth)

字段备注

auth_id用户id

openid第三方用户唯一标识

login_type第三方平台标识(qq、wechat...)

access_token第三方获取的access_token,校验使用

说明

users表只是单纯针对我们业务侧的登录,主要是做自身业务的oauth2.0业务,

user_local_auth是做自己用户名、密码登录,手机号码登录信息记录,

user_third_auth是我们第三方用户体系的数据记录,

user_auth_rel是用来关联我们users表与user_local_auth、user_third_auth。

整个设计理念就是将自建用户与第三方在存储上区分,这在架构演进上也是合乎情理的,开始用户体系大多自建,而后才是对外接入。

总结

总的来讲,第三方用户的接入技术上来讲是比较简单的,这里设计多一个user_thirds是可以支持足够多的第三方接入,当然一般我们也就两三个登录就好,太多登录方不仅自身维护成本,界面摆盘也不好看不是。

希望大家能够通过以上学习,能够对于我们多账户登录有一个比较好的认知,这里设计方案不包含分表分库、没有服务化,就是简单直接的设计,当然用户量和需要的不一样,在这个基础上还要加很多东西,谢谢大家阅读!

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/lvlei19911108/article/details/117842298

智能推荐

通信工程实施室内分布系统设计_室内天馈分布系统-程序员宅基地

文章浏览阅读319次。室内分布_室内天馈分布系统

【Python round()和int()】_python int round-程序员宅基地

文章浏览阅读211次。也就是整数部分是奇数,四舍五入后加1;整数部分是偶数的,四舍五入后不变。这里需要注意的是:round(x.5)的,例如。round() 四舍五入。_python int round

‘labelimg‘ 不是内部或外部命令,也不是可运行的程序 或批处理文件。_labelimg jpegimages predefined_classes.txt 'labeli-程序员宅基地

文章浏览阅读1.2w次,点赞11次,收藏10次。复制这个安装路径(注意这个大小写,开头字母改成大写才行)并且找到它。但是在本地电脑里面直接搜索路径特别的慢,这里推荐使用Everything这个软件,在我曾经写过的一篇分享文章中有。找文件特别的方便,而且体积也特别小(短小精悍)而关于在命令行中无法直接使用命令打开它,是因为环境配置原因。如果经常使用的话,可以直接复制一份到桌面使用。首先确保Anaconda的环境配置正确。找到可以直接双击打开它。_labelimg jpegimages predefined_classes.txt 'labelimg' 不是内部或外部命令,也

数据解析之Xpath解析(超详细定位)-程序员宅基地

文章浏览阅读5.5k次,点赞35次,收藏126次。XPath(XML Path Language)是一种XML的查询语言,他能在XML树状结构中寻找节点。XPath 用于在 XML 文档中通过元素和属性进行导航xml是一种标记语法的文本格式,xpath可以方便的定位xml中的元素和其中的属性值。lxml是python中的一个第三方模块,它包含了将html文本转成xml对象,和对对象执行xpath的功能表达式说明举例从根节点开始选取//从任意节点开始选取//input选取当前节点..选取当前节点的父节点//input/.._xpath

Linux文本三剑客---sed经典案例-程序员宅基地

文章浏览阅读776次,点赞11次,收藏26次。sed是一种流编辑器,它一次处理一行内容。处理时,把当前处理的行存储在临时缓冲区中,称为“模式空间”,接着用sed命令处理缓冲区中的内容,处理完成后,把缓冲区的内容送往屏幕。接着处理下一行,这样不断重复,直到文件末尾。文件内容并没有改变。

PHP与HTTP代理:解决网络请求限制的有效方法-程序员宅基地

文章浏览阅读375次,点赞9次,收藏9次。确保代理服务器的稳定性和速度,以及代理IP的质量和可用性。当然,在使用HTTP代理时,我们也需要注意合法性和稳定性等方面的问题,确保应用的正常运行和数据的准确性。当PHP应用向目标服务器发送请求时,如果直接发送可能会受到各种限制,但通过HTTP代理,请求会先发送到代理服务器,再由代理服务器转发到目标服务器。同时,HTTP代理还可以帮助我们隐藏真实的网络环境,突破某些地区的网络封锁或限制。无论是由于目标服务器的访问频率限制,还是由于网络环境的限制,这些都可能阻碍我们正常地获取数据或进行其他网络操作。

随便推点

二分图-程序员宅基地

文章浏览阅读869次,点赞18次,收藏4次。不要轻易放弃,最后悔的不是做错,而是错过。

Unix和Linux系统中常见的shell_linux/unix shell-程序员宅基地

文章浏览阅读291次,点赞5次,收藏8次。Unix和Linux系统中常见的shell_linux/unix shell

指针常量与常量指针_指针常量和常量指针-程序员宅基地

文章浏览阅读1.6k次,点赞4次,收藏10次。C/C++,指针常量与常量指针,所以在写代码时,如果要把一个变量的地址赋值给指针,若变量本身被const修饰,那么应该把地址赋值给常量指针,避免通过指针修改了变量本身。不能通过该指针修改其指向的值,即如果用常量指针操作指向的数据时,只能读不能写。先记住指针常量,联系数组名的值是一个地址,也就是地址常量,其实地址常量等价于指针常量。那么因为知道数组名的值(自身值)是不能改变的,而数组内的元素(指向的值)是可以改变的。不能改变存储的地址,即不能改变指针的指向。以上代码本意是a的值不可修_指针常量和常量指针

MDK仿真时闪退问题解决方案_mdk debug simulator的时候闪退-程序员宅基地

文章浏览阅读4.2k次,点赞3次,收藏2次。MDK仿真时闪退问题解决方案1,打开注册表2,Win+R键呼出“运行”,在框内输入“Regedit ”,回车打开注册表。3,如果弹出“是否允许此应用对你的计算机进行更改”的权限提示,选择“是”在注册表中,找到并进入HKEY_CURRENT_USER\Software\Microsoft\Windows NT\CurrentVersion\AppCompatFlags\Layers 若发现有..._mdk debug simulator的时候闪退

重新开始学stm32(5)PWM输出实验和正交编码器实验(1)-程序员宅基地

文章浏览阅读933次,点赞2次,收藏9次。今天继续我们的stm32回顾之路,今天的回顾的实验是PWM输出实验和输入捕获实验,为什么今天博主要把这两个实验放在一起讲呢?而且今天我们讲的输入捕获实验和正点原子的是不一样的。这是博主根据这两个内容在实际项目中的联系和使用最终决定的。接下来我们进入正题,看看为什么把这两个实验放在一起,它们有什么联系?_正交编码器

SAP HANA 创建SLT_hana slt-程序员宅基地

文章浏览阅读1.1k次,点赞31次,收藏22次。4.3.2 生成表 /1LT/SAPL&SID&15位编码,其中SID是SLT系统的SID号,本项目中是SLP,例如/1LT/SAPLSLP100000000000094,通过该表确定实际业务表,SLT系统中SE16查看表DMC_FMID,将上述表中的15位编码填入IDENT,查找COBJ_GUID,之后将COBJ_GUID填入到表DMC_COBJ的GUID中。在“系统数据”下,选择“RFC连接”单选按钮,指定到目标系统的RFC连接,并指定以下信息:RFC通信场景,从下拉列表中选择“标准RFC场景”选项。_hana slt

推荐文章

热门文章

相关标签