第三方授权登录的用户表设计实现

目录

介绍

业务流程

数据库脚本

用户表

用户应用表

代码实现

Controller

Service

Mapper

entity

Mapper.xml

API接口演示

请求参数

响应结果


介绍

第三方登录,主要介绍一个系统兼容多个移动端应用来设计

手机号唯一,识别多平台多小程序业务场景,多个平台共用一个手机号,手机号唯一

用户id

手机号

应用appId

应用unionId

100

15010086100

123456

123456890

123457

123457890

表结构关系表示如下:

主表必要字段

主键ID

手机号

邮箱

用户昵称

头像

性别

备注

删除状态

创建时间

12345

150****1000

用户12345

12346

150****1001

用户12346

附表必要字段

用户ID

来源平台

APPID

unionId

openId

删除状态

创建时间

12345

1

123456

123456890

12345681

1

123457

123457890

12345781

来源平台字段:1、微信小程序、2、微信公众号、3、网页H5 4、支付宝,9、其他

业务流程

业务实现流程

数据库脚本

postgresql数据库脚本

用户表

C端用户主表
-- 新增第三方C端用户表:C端用户主表
DROP TABLE IF EXISTS "pig"."sys_third_user";
CREATE TABLE "pig"."sys_third_user" (
                                        "id" serial8 primary key,
                                        "phone" varchar(255) COLLATE "pg_catalog"."default",
                                        "email" varchar(255) COLLATE "pg_catalog"."default",
                                        "nickname" varchar(255) COLLATE "pg_catalog"."default",
                                        "avatar" varchar(500) COLLATE "pg_catalog"."default",
                                        "gender" int4 DEFAULT 0,
                                        "remark" text COLLATE "pg_catalog"."default",
                                        "platform" int4 DEFAULT 0,
                                        "lock_flag" char(1) COLLATE "pg_catalog"."default" DEFAULT '0'::bpchar,
                                        "del_flag" char(1) COLLATE "pg_catalog"."default" DEFAULT '0'::bpchar,
                                        "create_time" timestamp(6),
                                        "update_time" timestamp(6)
);
COMMENT ON COLUMN "pig"."sys_third_user"."id" IS 'ID';
COMMENT ON COLUMN "pig"."sys_third_user"."phone" IS '手机号';
COMMENT ON COLUMN "pig"."sys_third_user"."email" IS '邮箱';
COMMENT ON COLUMN "pig"."sys_third_user"."nickname" IS '用户昵称';
COMMENT ON COLUMN "pig"."sys_third_user"."avatar" IS '头像地址';
COMMENT ON COLUMN "pig"."sys_third_user"."gender" IS '性别:0未知,1男,2女';
COMMENT ON COLUMN "pig"."sys_third_user"."remark" IS '备注信息';
COMMENT ON COLUMN "pig"."sys_third_user"."platform" IS '对接平台:1智慧工地,2智慧农业';
COMMENT ON COLUMN "pig"."sys_third_user"."lock_flag" IS '0-正常,9-锁定';
COMMENT ON COLUMN "pig"."sys_third_user"."del_flag" IS '0-正常,1-删除';
COMMENT ON COLUMN "pig"."sys_third_user"."create_time" IS '创建时间(只读)';
COMMENT ON COLUMN "pig"."sys_third_user"."update_time" IS '更新时间';
COMMENT ON TABLE "pig"."sys_third_user" IS 'C端个人用户表';
CREATE INDEX IF NOT EXISTS  idx_sys_third_user_phone  ON "pig"."sys_third_user" (phone, del_flag);

用户应用表

C端用户应用关联表
-- 新增第三方C端用户附表:C端用户主表的附表
DROP TABLE IF EXISTS "pig"."sys_third_user_app";
CREATE TABLE "pig"."sys_third_user_app" (
                                            "id" serial8 primary key,
                                            "user_id" int8,
                                            "origin" int4 DEFAULT 0,
                                            "platform" int4 DEFAULT 0,
                                            "app_id" varchar(255) COLLATE "pg_catalog"."default",
                                            "union_id" varchar(255) COLLATE "pg_catalog"."default",
                                            "open_id" varchar(255) COLLATE "pg_catalog"."default",
                                            "remark" text COLLATE "pg_catalog"."default",
                                            "del_flag" char(1) COLLATE "pg_catalog"."default" DEFAULT '0'::bpchar,
                                            "create_time" timestamp(6),
                                            "update_time" timestamp(6)
);
COMMENT ON COLUMN "pig"."sys_third_user_app"."id" IS 'ID';
COMMENT ON COLUMN "pig"."sys_third_user_app"."user_id" IS '用户id';
COMMENT ON COLUMN "pig"."sys_third_user_app"."origin" IS '应用平台来源:1、微信小程序、2、微信公众号、3、网页H5  4、支付宝,9、其他';
COMMENT ON COLUMN "pig"."sys_third_user_app"."platform" IS '对接平台:对接平台:1智慧工地,2智慧农业';
COMMENT ON COLUMN "pig"."sys_third_user_app"."app_id" IS '应用appId';
COMMENT ON COLUMN "pig"."sys_third_user_app"."union_id" IS '用户的unionId';
COMMENT ON COLUMN "pig"."sys_third_user_app"."open_id" IS '用户的openId';
COMMENT ON COLUMN "pig"."sys_third_user_app"."remark" IS '备注信息';
COMMENT ON COLUMN "pig"."sys_third_user_app"."del_flag" IS '0-正常,1-删除';
COMMENT ON COLUMN "pig"."sys_third_user_app"."create_time" IS '创建时间(只读)';
COMMENT ON COLUMN "pig"."sys_third_user_app"."update_time" IS '更新时间';
COMMENT ON TABLE "pig"."sys_third_user_app" IS 'C端个人用户表附表';
CREATE INDEX IF NOT EXISTS  idx_sys_third_user_app_user_id  ON "pig"."sys_third_user_app" (user_id, del_flag);

代码实现

前端注册登录参数

{
	"loginWay": 2,
	"phone": "15010089100",
	"nickname": "AE86100",
	"avatar": "",
	"gender": 1,
  	"origin": 1, 
    "platform": 2,
    "appId": "wx7656607fe455999",
    "unionId": "oIZP66apYo_q3zmvBbH2CgAzv6H1",
	"openId": "onLIm4y_qedXy7JPgyC8-iEhOkc1",
	"remark": "remark",
	"code": "123456"
}

Controller

接口入参对象:ThirdUserDTO.java

package com.pig4cloud.pig.admin.api.dto;

import io.swagger.v3.oas.annotations.media.Schema;
import lombok.Data;

import javax.validation.constraints.NotBlank;
import javax.validation.constraints.NotNull;
import java.io.Serializable;

/**
 * @author: 可乐加糖
 * @createTime: 2023年05月18日 13:59
 * @description: -小程序获取手机号
 */
@Data
@Schema(description = "C段用户注册")
public class ThirdUserDTO implements Serializable {

	@Schema(description ="ID")
	private Long id;

	@Schema(description ="手机号")
	private String phone;

	@Schema(description ="邮箱")
	private String email;

	/**
	 * 国际区号码
	 */
	@Schema(description ="国际区号码")
	private String dialCode;


⽤户登录系统数据库表设计 ⽤户登录系统数据库表设计 最近看了看公司后台⽤户登录系统的设计, ⽐较混乱, 主要还是因为URS和Oauth以及URS第三⽅这三个登录形式各不相同导致的。 下⾯着重介绍⼀下涉及到第三⽅登录中需要注意的问题 在⼀个新项⽬中, 如果是要建⽴⾃⼰的登录体系的话, 那么直接创建⼀个Users表,包含username和password两列,这样,就可以实现登录了: id " username " password " name等其他字段 ----+----------+----------+---------------- A1 " bob " a1b23f2c " ... A2 " adam " c0932f32 " ... 如果要让⽤户通过第三⽅登录,⽐如微博登录或QQ登录,怎么集成进来呢? 以微博登录为例,由于微博使⽤OAuth2协议登录,所以,⼀个登录⽤户会包含他的微博⾝份的ID,⼀个Access Token⽤于代表该⽤户访问微博的API和⼀个过期时间。 要集成微博登录,很多童鞋⽴刻想到把Users表扩展⼏列,记录下微博的信息: id " username " password " weibo_id " weibo_access_token " weibo_expires " name等其他字段 ----+----------+----------+----------+--------------------+---------------+---------------- A1 " bob " a1b23f2c " W-012345 " xxxxxxxxxx " 604800 " ... A2 " adam " c0932f32 " W-234567 " xxxxxxxxxx " 604800 " ... 加⼀个QQ登录Users表就⼜需要加3列,⾮常不灵活 那么我们需要对这个表进⾏拆分。当⽤户以任意⼀种⽅式登录成功后,我们读取到的总是Users表对应的⼀⾏记录,它实际上是⽤户的个⼈资料(Profile),⽽登录过程只是为了 认证⽤户(Authenticate),⽆论是本地⽤密码验证,还是委托第三⽅登录,这个过程本质上都是认证。 所以,如果把Profile和Authenticate分开,就⼗分容易理解了。Users表本⾝只存储⽤户的Profile, 其中ID为关联不同登录⽅式的外键。 id " name " birth等其他字段 ----+------+----------------- A1 " Bob " ... A2 " Adam " ... ⽽通过⽤户名⼝令登录可视为⼀种Authenticate的⽅式,利⽤LocalAuth表维护: id " user_id " username " password ----+---------+----------+----------- 01 " A1 " bob " a1b23f2c 02 " A2 " adam " c0932f32 通过微博登录可视为另⼀种Authenticate⽅式,利⽤OAuth表维护, 但是access_token⼀般情况也只有⼏个⼩时的时效, 所以存储它是没有意义的, 每次登录的时候去微博后台 验证⼀下客户端传来的token就⾏了。 如果⽤户只⽤了第三⽅登录, 那就拿第三⽅数据来填充刚才的User表即可。 id " user_id " weibo_id " ----+---------+----------+ 11 " A1 " W-012345 " 12 " A2 " W-234567 " 如果要添加另⼀种OAuth登录,⽐如QQ登录,那就再加⼀个列标⽰不同站点也就OK了, 但是要注意⽤户在不同登录⽅式的⽤户名和photo⼀般不⼀样, 所以也单独存起来 id " user_id " oauth_name " oauth_id " nick_name" photo" ----+---------+------------+----------+----------+------+ 11 " A1 " weibo " W-012345 " 12 " A2 " weibo " W-234567 " 13 " A1 " qq " Q-090807 " 14 " A2 " qq " Q-807060 " 通过这种⽅式, ⽆论⽤户采⽤哪种⽅式登录, 都可以锁定到⽤户的user_id。 下⾯再说⼀下⽹易的URS登录, 因为我们要直接采⽤⽹易通⾏证, 所以也就不需⾃⼰存储密码, 因此我们的架构应该设为User表 id " user_Email " username " birth ----+------------+----------
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值