名称解释

这里的多账户区别于系统级别的,我们讲的多账户系统是指,在我们互联网应用当中,我们的应用会使用多个第三方账号进行登录,必须现在常用的APP(网易云音乐)登录方式包含:网易、微信、QQ

内容

通过这一篇文章

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

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

架构演进

创业初期

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

用户名密码注册登陆

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

流程图:

流程说明:

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

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

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

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

手机号注册登陆

流程图:

流程说明:

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

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

成功后就进行登录操作。

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

问:那我要密码咋办?

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

数据库设计

表结构

说明

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

引入第三方账户方案

这里是以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_auth_rel)

本地用户表(user_local_auth)

第三方用户表(user_third_auth)

说明

  • users表只是单纯针对我们业务侧的登录,主要是做自身业务的oauth2.0业务,
  • user_local_auth是做自己用户名、密码登录,手机号码登录信息记录,
  • user_third_auth是我们第三方用户体系的数据记录,
  • user_auth_rel是用来关联我们users表与user_local_auth、user_third_auth。
  • 整个设计理念就是将自建用户与第三方在存储上区分,这在架构演进上也是合乎情理的,开始用户体系大多自建,而后才是对外接入。

总结

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

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


作者:低调的码农
链接:https://juejin.im/post/5d0a298bf265da1b827aa06f
来源:掘金

android新浪微博sdk登录获取用户名_多账户的统一登录方案相关推荐

  1. android 微博 4.1sdk,Android新浪微博SDK分享功能接入

    集成前准备 1. 申请APP_KEY 第三方需要接入微博SDK必须在微博开放平台上对应用进行注册,并获取APP_KEY,添加 应用的授权回调页面(Redirect URI) 2. 注册应用程序的包名和 ...

  2. 预登录握手失败_英雄联盟手游登录问题汇总

    1.出现"无法安装完成"的情况 已经获取了资格,但出现"无法安装完成"的情况,譬如谷歌商店的下载界面一直闪退.下载没进度.卡在安装中.卡在等待中怎么办? 可前往 ...

  3. python模拟登录教务系统_用Python实现模拟登录正方教务系统抢课

    最近学校开始选课,但是如果选课时间与自己的事情冲突,这时候就可以使用Python脚本自助抢课,抢课的第一步即是模拟登录,需要模拟登录后保存登录信息然后再进行操作. 而且整个流程是比较简单,这是因为正方 ...

  4. aspnet登录界面代码_英雄联盟手游登录问题汇总

    1.出现"无法安装完成"的情况 已经获取了资格,但出现"无法安装完成"的情况,譬如谷歌商店的下载界面一直闪退.下载没进度.卡在安装中.卡在等待中怎么办? 可前往 ...

  5. 微信小程序手机号一键登录--获取用户手机号--微信小程序一键登录

    前提:现在微信小程序登录我参考了几个大的公司的登录,基本分下面几种 1.微信用户一键登录,授权用户基本信息,不获取手机号 2.微信手机号一键登录,根据手机号去关联在其他平台数据,用手机号关联.然后再调 ...

  6. 使用qt设计登录界面初学者_初学者素描:设计登录表单界面

    使用qt设计登录界面初学者 由Bohemian Coding的好伙伴制作的Sketch是界面设计的出色程序. 本入门级教程将向您介绍使用Sketch进行设计. 您将不需要任何程序经验,只需要一些空闲时 ...

  7. Android新浪微博登陆和获取个人信息

    自己总结的一些android新浪登陆和根据用户ID获取用户信息,以下代码只是写了重要的部分,详细代码可到新浪官方下载一个Demo,里面都有详细流程和各种API. Constant.java   常量类 ...

  8. 微信小程序授权登录获取用户名和昵称

    微信授权官方文档 登录流程时序: 这里我是用微信开发者工具写的前端 login.wxml代码: <view class="userinfo"><block wx: ...

  9. ie自动获取无效_经常用浏览器自动登录忘记了密码?教你一键查看网页星号密码...

    不知道大家有没有出现这种情况,因为一直用的网页自动填写密码来登录,所以有时候甚至把密码给忘了 相信有的小伙伴有可能就会出现这种情况哈,今天小林君来教你个超简单的方法,不用安装任何软件,就可以一键查看网 ...

最新文章

  1. SD-WAN:MSP连接
  2. 求职必备技能:教你如何扒了公司的底裤!
  3. 匠心功能农业-农业大健康·弘本农业:对话农民丰收节交易会
  4. ADO.NET Entity Framework之ObjectQuery
  5. ci中如何得到配置的url
  6. mysql 权重 取值_mysql如何按权重查询数据啊?
  7. CSS之REM和EM的区别
  8. 推荐几款好用的模态框附带教程
  9. Ionic Cordova 环境配置window
  10. JAVA语言程序设计(基础篇)——第四章例题
  11. WCF笔记--泛型与集合数据类型
  12. 成功软文营销经典案例-案例分享
  13. Docker镜像下载加速的两种方法
  14. 生成器模式及C++代码实现
  15. Python解答蓝桥杯省赛真题之从入门到真题
  16. indesign用于产品排班_怎样利用Indesign来进行高效的排版ID:30077776
  17. filezilla,filezilla下载文件
  18. 什么是高斯模糊算法?
  19. windows的文件路径文件(夹)名的分割符也可以用正斜杠
  20. 【语音去噪】基于matlab软阈值+硬阈值+折中阈值语音去噪【含Matlab源码 530期】

热门文章

  1. 6.(Mysql数据管理相关)连接MYSQL,修改密码,增加新用户,数据库相关命令,表操作相关命令,数据相关命令,数据库sql导入和导出,备份数据库,查看不到mysql数据库的解决办法
  2. CSS中一个font缩写的实例
  3. SQL基础操作_7_时间运算
  4. 获取对话框当前cfont_自绘对话框
  5. Linux驱动编程 step-by-step (一)驱动程序的作用
  6. Unity C#基础之 反射反射,程序员的快乐
  7. 一、MySQL数据库基础
  8. Tomcat+Nginx+Memcached集群部署
  9. java处理高并发高负载类网站的优化方法
  10. think in uml-关系