基于SpringBoot的密码找回功能实现

前言

最近在做自己的项目,其中有一个大家都知道的功能就是找回密码。这里分享一下我的做法,因为这中间实在有太多坑了。所以记录一下。

使用技术:SpringBoot1.5.6、JPA、SpringSecurity4、MySQL、BootStrap等等等。。。

密码找回流程图:

首先,先来给大家介绍一下密码找回的基本原理:

接着,按照流程图我们来实现一下首先第一步是点击跳转到找回密码界面:我用的是这种方式大家随意

找回密码界面为:

第二步:判断输入的账户是否有效

下面是如果存在的话就生成URL链接:

backPassword:

第三步:判断重置表中是否有该账户,重置表是一张保存URL的表(过期时间、sid、账户信息等)

这样做的目的是:如果存在该条数据而不去删除的话,下次找回密码的时候就会生成2条账户一样,但是sid不一样的数据,这样的坏处是:发邮件的时候不知道该返回哪个URL,因为有2条URL

第四步:邮件发送

我们先来看下效果:

接下来就是重要部分:如何处理验证链接,首先我们可以看到/user/reset_password这个是一个请求后面是它的参数,所以切记!

我们要写一个请求,路由就是/user/reset_password,与此同时需要在SpringSecurity中对该请求放行。验证的过程是这样的:首先把从请求传过来的sid和userName(也就是邮箱)和数据库中的sid和account比对,同时还要对比时间是否是在有效期30分钟内,如果这些都满足的话就返回true,否则为false。需要注意的是:这里有一个替换是空格替换为+号,是因为HTML传给后台的时候+号被自动转为了空格,如果不替换为+号的话就会一直提示验证失败!!!一旦返回true的话就代表验证URL通过,就跳转到重置密码界面:

注意:我这里没有对验证进行优化,不应该有这么多的if else嵌套

对请求路由进行放行:如果不放行的话点击链接就会跳转至登录界面

跳转到重置页面,如果我们这时2次输入的密码不一致就会有如下的提示,我这个是使用JS做的校验:

当然为了严谨我们在后台也进行2次密码校验,如果输入的是一致的话才去更新信息,不一致的话就返回错误

这里倒是没什么,就是注意下在密码保存到数据库之前,使用MD5+盐加密一下,之后保存就可以,我们来看下2次密码输入正确的效果:页面提示修改成功后台无报错,这时候使用新密码就可以进行登录

  • 4
    点赞
  • 45
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
SpringBoot实现忘记密码功能可以使用以下步骤: 1. 前端页面:创建一个表单,用户可以输入注册时使用的邮箱地址。 2. 后端验证:在后台,使用JPA和Spring Security验证用户输入的邮箱是否存在于数据库中。如果邮箱存在,就生成一个验证码并将其保存到数据库中,同时将验证码发送到用户注册时使用的邮箱。 3. 邮箱验证:用户收到邮件后,点击邮件中的链接,并跳转到一个新的页面。在这个页面上,用户需要输入之前收到的验证码以及新的密码。 4. 密码更新:在后台,使用MD5加密算法对新的密码进行加密,并将其保存到数据库中。同时,将验证码从数据库中删除,以确保每个验证码只能使用一次。 5. 提示用户:在页面上给用户一个成功修改密码的提示,并提供一个登录按钮,让用户可以使用新的密码登录。 通过以上步骤,用户就可以使用SpringBoot实现忘记密码功能了。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *3* [基于SpringBoot密码找回功能实现](https://blog.csdn.net/qq_32967665/article/details/86661154)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] - *2* [springboot注册登录忘记密码+前台提交表单后台审核+邮箱验证+用户下载.zip](https://download.csdn.net/download/weixin_44005325/20395258)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值