Echo 的注册功能是怎么做的
用户注册,会输入用户名、密码和邮箱,密码需要加盐加密再存入数据库:
![](https://filescdn.proginn.com/789ff9b71ee96adc5948e2aeb28fc245/b4e531183b590f5a96c69e7ecf6d7160.webp)
另外,默认未激活的用户状态 status=0 也会存入数据库,当然,我们会为该注册用户随机生成一个唯一的激活码一并存入数据库:
![](https://filescdn.proginn.com/8e9e42e0731d8b93bb41624763ce9346/b58fbb44be16959b081167b936274653.webp)
这个激活码的作用就是用来激活该用户的。在本地环境下:http://localhost:8080/greatecommunity/activation/用户id/激活码
就是该用户的激活链接;在服务器上:服务器公网 IP 地址/activation/用户id/激活码
就是该用户的激活链接。点击该激活链接则激活对应的用户,也就是修改数据库中用户表的字段 status 为 1,未激活的用户同样无法正常使用某些功能比如发表帖子等。
激活链接的校验逻辑也很简单,就是检查一下这个链接中的用户 id 和激活码是否和数据库中存储的一样:
![](https://filescdn.proginn.com/b6be343d80a9bb0b550ec6f5192e26fe/01cbb9cb97b794e2786323ddffdc5538.webp)
那么这个激活链接是如何发送给用户的呢?通过邮件。我们使用 Spring Mail 给这个用户的邮箱发送激活邮件,这个激活邮件中就包含该用户的激活链接:
![](https://filescdn.proginn.com/ba1b5a10c674d62ec0c64b9939e5fb05/d34e5250a9a0b802f4d2d7415db97e21.webp)
对应的激活邮件模板在 /mail/activation.html
:
![](https://filescdn.proginn.com/73983c46a73d4db8bf8951648b6ee454/b1ad9653eec682db1692a44d074014ba.webp)
另外,用户注册的时候会为该用户生成一个随机头像,这个头像的地址会被存入 user 表。这个随机头像的实现其实很简单,用的是牛客的一个头像库,包含了 1000 张头像图片,比如第 66 张图片的访问地址就是 http://images.nowcoder.com/head/66t.png
,所以我们随机生成 1000 以内的数字就好了:
![](https://filescdn.proginn.com/e10229a819236a1dfef1f1c7e15162eb/e81fd69ab927447ab66ea871f2604022.webp)
OK,注册的逻辑还是很简单的吧,各位可以结合下图来看:
![](https://filescdn.proginn.com/31a34c783835efd83997a932c1a9bd30/374695f38712d06a2fe5d2e5eeb66a0a.webp)
![](https://filescdn.proginn.com/cf4f97158a9a913fd024d2fdc6fbab01/d41bee0c6df32d21ee17afce571b1d85.webp)
公众号开通较晚,暂无留言功能。各位可以点击下方链接进行留言
评论