首页 > 类似值乎和分答之类的产品,在架构上是怎么区分普通用户和回答者的身份的?

类似值乎和分答之类的产品,在架构上是怎么区分普通用户和回答者的身份的?

一个WebApp,同时拥有两类用户,一类是提问的,一类是回答的,那如何才能更好地维护这两种身份及各自的状态?

方案一:同一个人需要注册两遍,一个账号是用户一个账号是回答者,切换身份需要先登出然后选择身份重新登录,这样似乎比较清晰

方案二:所有用户在初始状态下都是普通用户,而要晋升成为回答者的话,需要提交某种申请,通过后,在原有用户信息下添加回答者的标记,相对应的展示内容也会有所变化,甚至可以说,可能回不到普通用户的状态了

方案三:两类用户注册流程完全相同,注册完成后统一跳转登录页面,在登录页面选择一种身份登录,其实这个就是在单个账号下区分身份,切换也需要重新登录

分答只是举个例子,这两类用户的用户行为其实有很大不同的,在一些内容展现上也会有所区分,举几个例子,一类是病人,一类是医生,一类是司机,那么另外一类是乘客,那么是采用哪一种方案更好管理和维护呢?

不知道我描述的是否清晰,希望有做过双端或者多身份账户登录的经验人士指点指点


知乎是不需要双端的,每个人即可以是提问者也可以是回答者。你在别人的问题下就是回答者,同时你可以提新问题。注册和用户管理都是一套,根据页面逻辑确定角色。

滴滴打车是需要双端的,因为司机和乘客完全是两类人两类行为,所以注册和用户管理都是两套

boss直聘这种比较特殊,注册和用户管理是一套流程,和知乎相似。但角色切换是主动进行的,而不是应用根据逻辑赖自动帮你选。在用户登录后会让你选择是招聘者还是应聘者,然后进入对应的页面,以后所有的行为都是对应的角色。当然在使用中也可以主动切换角色


我采取的方案

数据库设计相关:
所有角色用户信息都存一个基础信息表,然后每个角色都有对应的信息外表
比如基础信息表存储用户名、昵称、密码、手机、邮箱,外表:普通会员信息表、商户信息表等

业务流程相关:

【热门文章】
【热门文章】