怎么实现第三方登录
现在很多第三方登录都是使用的,我在项目中使用的是GitHub第三方登录
第一步先要在GitHub上配置自己的服务器地址和回调的地址
- 用户点击登录,到ClientServer
- ClientServer通过redirect到GitHub认证服务器
- 服务器检查请求,并返回登录表单页面
- 用户填写后,发送给认证服务器
- 认证服务器检查正确性,并返回authorization_code给ClientServer
- 然后ClientServer使用在GitHub配置的路径并带上authorization_code
- 认证服务器验证code是否正确,正确的话就给服务端发一个access_token
- 然后通过Http发送post请求到https://github.com/login/oauth/access_token并携带access_token
- 然后才到资源服务器(GitHub服务器)通过认证,返回用户信息
10.服务端接受后,返回到前端
雪花算法生成分布式ID
采用Long类型64位ID
- 第一位是标识,正数0(一般为0,id一般是正数),负数1
- 41位时间戳(毫秒级)存的是距离开始时间的差值,41位的时间截,可以使用69年,年T = (1L << 41) / (1000L * 60 * 60 * 24 * 365) = 69
- 10位的数据机器位,可部署在1024个节点
- 12位序列,毫秒内的计数
1+42+10+12=64位刚好是一个Long