Heim > Java > javaLernprogramm > Hauptteil

So implementieren Sie die Ein-Klick-Registrierung und Anmeldung mit dem Bestätigungscode für die Mobiltelefonnummer im Java- und JavaScript-Frontend und -Backend

WBOY
Freigeben: 2023-05-03 08:46:06
nach vorne
1928 Leute haben es durchsucht

一、一键注册登录流程

So implementieren Sie die Ein-Klick-Registrierung und Anmeldung mit dem Bestätigungscode für die Mobiltelefonnummer im Java- und JavaScript-Frontend und -Backend

二、前端

2.1. 验证码获取流程

1.点击->获取验证码调用后端获取验证码api接口

2.验证码59秒倒计时

3.重复点击获取验证码,判断验证码倒计时是否大于0:

  • 如果大于0,获取验证码按钮不可触摸

  • 如果等于0,获取验证码调用后端获取验证码api接口

2.2. 验证码获取代码

	var serverUrl = app.globalData.serverUrl;
				// 调用后端发送验证码
				uni.request({
					method: "POST",
					url: serverUrl + "/passport/getSMSCode?mobile=" + mobile,
					success(result) {
						var status = result.data.status;
						if (status != 200) {
							uni.showToast({
								title: result.data.msg,
								icon: "none"
							});
						}
						// 开始倒数60秒限制
						if(me.codeTimes == 0) {
							me.doTimer(59);
						}
					}
				});	
			},
			// 发送验证码的倒计时方法
			doTimer(times) {
				var me = this;
				// 倒计时定时器
				var sendCodeBtnFunction = function(){
					var left = times--;
					if (left <= 0) {
						me.codeTouched = false;
						me.codeBtnText = "发送验证码";
						clearInterval(smsTimer);
					} else {
						me.codeBtnText = left + "s";
					}
					me.codeTimes = left;
				};
				var smsTimer = setInterval(sendCodeBtnFunction, 1000);
			},
Nach dem Login kopieren

三、后端验证码

3.1. 前置处理

由于为了避免频繁获取验证码导致无效的操作,因此,对验证码获取逻辑需要进行前置拦截处理。

根据用户ip进行限制,限制用户在60秒之内只能获得一次验证码

先进入->验证码前置拦截处理:

1.获取用户的ip

2.验证码redis存储key的前缀+获取用户的ip当做redis中的key,从redis中获取已经存储的请求请求ip

  • 如果redis中存在未过期的用户请求ip,则提示"短信发送太快啦~请稍后再试!"

  • 如果redis中,不存在用户请求ip,则放行,继续调用获取验证码接口api

So implementieren Sie die Ein-Klick-Registrierung und Anmeldung mit dem Bestätigungscode für die Mobiltelefonnummer im Java- und JavaScript-Frontend und -Backend

3.2. 拦截器添加

So implementieren Sie die Ein-Klick-Registrierung und Anmeldung mit dem Bestätigungscode für die Mobiltelefonnummer im Java- und JavaScript-Frontend und -Backend

3.3. 获取验证码

1.对输入框填写的数据进行校验,不合法则提示,合法继续。

2.获得用户请求ip

3.根据用户ip进行限制,限制用户在60秒之内只能获得一次验证码

4.生成随机6位验证码

5.调用腾讯/阿里短信服务,发送验证码

6.把验证码放入到redis中,用于后续的验证

7.返回验证码

So implementieren Sie die Ein-Klick-Registrierung und Anmeldung mit dem Bestätigungscode für die Mobiltelefonnummer im Java- und JavaScript-Frontend und -Backend

Das obige ist der detaillierte Inhalt vonSo implementieren Sie die Ein-Klick-Registrierung und Anmeldung mit dem Bestätigungscode für die Mobiltelefonnummer im Java- und JavaScript-Frontend und -Backend. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Verwandte Etiketten:
Quelle:yisu.com
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage