From cfe04910a5b70d220dd1e6ac9b84328112c76808 Mon Sep 17 00:00:00 2001
From: 819527061@qq.com <123456>
Date: 星期五, 07 六月 2024 15:54:20 +0800
Subject: [PATCH] feture:密码强制修改及密码强度限制

---
 pages/register/register.vue |  227 ++++++++++++++++++++++++++++++++++++++++++--------------
 1 files changed, 170 insertions(+), 57 deletions(-)

diff --git a/pages/register/register.vue b/pages/register/register.vue
index 7fd5b29..774d10c 100644
--- a/pages/register/register.vue
+++ b/pages/register/register.vue
@@ -61,6 +61,21 @@
 						password
 						clearable></u--input>
 				</u-form-item>
+        <view class="intensity">
+          <view class="psdText">瀵嗙爜寮哄害</view>
+          <view
+              class="line"
+              :class="[level.includes('low') ? 'low' : '']"></view>
+          <view
+              class="line"
+              :class="[level.includes('middle') ? 'middle' : '']"></view>
+          <view
+              class="line"
+              :class="[level.includes('high') ? 'high' : '']"></view>
+          <div class="warningtext">
+            瀵嗙爜搴旂敱8-16浣嶆暟瀛椼�佸瓧姣嶃�佺鍙风粍鎴愩�傝涓嶈浣跨敤瀹规槗琚寽鍒扮殑瀵嗙爜
+          </div>
+        </view>
 				<u-form-item prop="confirmPassword"
 					label="纭瀵嗙爜"
 					labelWidth="20%"
@@ -69,8 +84,7 @@
 					<u--input v-model="registerFormModel.confirmPassword"
 						placeholder="璇疯緭鍏ュ唴瀹�"
 						password
-						clearable
-						@blur="jiaoYanPassword"></u--input>
+						clearable></u--input>
 				</u-form-item>
 				<u-form-item prop="carNo"
 					label="杞︾墝鍙�"
@@ -241,7 +255,83 @@
 			}
 		},
 		data() {
+      const validatePass = (rule, value, callback) => {
+        if (this.registerFormModel.confirmPassword !== "") {
+          if (value !== this.registerFormModel.password) {
+            callback(new Error("涓ゆ杈撳叆瀵嗙爜涓嶄竴鑷�!"));
+          } else {
+            callback();
+          }
+        } else {
+          callback();
+        }
+      };
+      const checkPassword = (rule, value, callback) => {
+        // let roles = this.$store.getters.roles;//褰撳墠鐢ㄦ埛瑙掕壊id
+        // let passL = 8;
+        // if (roles.concat(1)){
+        //   passL = 10
+        // }
+        let passL = 8;
+        this.level = []
+        if(!value) {
+          return callback('瀵嗙爜涓嶈兘涓虹┖')
+        }
+        if(value.length < passL) {
+          return callback(`瀵嗙爜涓嶈兘灏戜簬${passL}浣峘)
+        }
+        if(value.length > 16) {
+          return callback('瀵嗙爜涓嶈兘澶т簬16浣�')
+        }
+        //鏍¢獙鏄暟瀛�
+        const regex1 = /^\d+$/
+        // 鏍¢獙瀛楁瘝
+        const regex2 = /^[A-Za-z]+$/
+        // 鏍¢獙绗﹀彿
+        const regex3 =
+            /^[`~!@#$%^&*()_\-+=<>?:"{}|,.\/;'\\[\]路~锛丂#锟�%鈥︹��&*锛堬級鈥斺�擻-+={}|銆娿�嬶紵锛氣�溾�濄�愩�戙�侊紱鈥�'锛屻�傘�乚+$/
+        if(regex1.test(value)) {
+          this.level.push('low')
+          return callback('瀵嗙爜寮哄害杩囦綆')
+        }else if(regex2.test(value)) {
+          this.level.push('low')
+          return callback('瀵嗙爜寮哄害杩囦綆')
+        }else if(regex3.test(value)) {
+          this.level.push('low')
+          return callback('瀵嗙爜寮哄害杩囦綆')
+        }else if(/^[A-Za-z\d]+$/.test(value)) {
+          this.level.push('low')
+          this.level.push('middle')
+          return callback()
+        }else if(
+            /^[`~!@#$%^&*()_\-+=<>?:"{}|,.\/;'\\[\]路~锛丂#锟�%鈥︹��&*锛堬級鈥斺�擻-+={}|銆娿�嬶紵锛氣�溾�濄�愩�戙�侊紱鈥�'锛屻�傘�乗d]+$/.test(
+                value
+            )
+        ) {
+          this.level.push('low')
+          this.level.push('middle')
+          return callback()
+        }else if(
+            /^[`~!@#$%^&*()_\-+=<>?:"{}|,.\/;'\\[\]路~锛丂#锟�%鈥︹��&*锛堬級鈥斺�擻-+={}|銆娿�嬶紵锛氣�溾�濄�愩�戙�侊紱鈥�'锛屻�傘�丄-Za-z]+$/.test(
+                value
+            )
+        ) {
+          this.level.push('low')
+          this.level.push('middle')
+          return callback()
+        } else if (
+            /^[`~!@#$%^&*()_\-+=<>?:"{}|,.\/;'\\[\]路~锛丂#锟�%鈥︹��&*锛堬級鈥斺�擻-+={}|銆娿�嬶紵锛氣�溾�濄�愩�戙�侊紱鈥�'锛屻�傘�丄-Za-z\d]+$/.test(
+                value
+            )
+        ) {
+          this.level.push('low')
+          this.level.push('middle')
+          this.level.push('high')
+        }
+        return callback()
+      };
 			return {
+        level:[],  //瀵嗙爜寮哄害鏁扮粍
 				// 杞︾墝鍙烽敭鐩樻帶鍒�
 				carNumShow: false,
 				keyValue: '',
@@ -320,23 +410,16 @@
 							message: '璇疯缃垵濮嬪瘑鐮�',
 							trigger: ['blur', 'change']
 						},
-						{
-							min: 6,
-							max: 12,
-							message: '闀垮害鍦�6-12涓瓧绗︿箣闂�'
-						}
+            {
+              validator: checkPassword,
+              trigger: 'change'
+            }
 					],
 					confirmPassword: [{
-							required: true,
-							message: '璇疯缃垵濮嬪瘑鐮�',
-							trigger: ['blur', 'change']
-						},
-						{
-							min: 6,
-							max: 12,
-							message: '闀垮害鍦�6-12涓瓧绗︿箣闂�'
-						}
-					],
+            required: true,
+            validator: validatePass,
+            trigger: "blur"
+          }],
 					carNo: [{
 							type: 'string',
 							required: true,
@@ -438,40 +521,36 @@
 		methods: {
 			...mapMutations(['changeisUploadimg']),
 			registerClick() {
-				if (this.registerFormModel.password == this.registerFormModel.confirmPassword) {
-					this.$refs.regesterFormRef
-						.validate()
-						.then(res => {
-							console.log(this.registerFormModel);
-							this.registerClickloading = true;
-							this.registerFormModel.username = this.registerFormModel.phone;
-							apiRegister(this.registerFormModel)
-								.then(res => {
-									this.registerClickloading = false;
-									if (res.data.code == 0) {
-										uni.showToast({
-											title: '娉ㄥ唽鎴愬姛,鍗冲皢杩斿洖鐧诲綍椤�',
-											icon: 'none',
-											duration: 1000
-										});
-										setTimeout(() => {
-											uni.redirectTo({ url: '/pages/login/login' });
-										}, 1000);
-									} else {
-										this.$u.toast(res.data.msg ? res.data.msg : '娣诲姞澶辫触');
-									}
-								})
-								.catch(err => {
-									console.log('閿欒', err);
-								});
-						})
-						.catch(err => {
-							console.log('err', err);
-							this.$u.toast('璇疯鑼冭緭鍏ュ唴瀹�');
-						});
-				} else {
-					this.$u.toast('涓ゆ瀵嗙爜涓嶄竴鑷�');
-				}
+        this.$refs.regesterFormRef
+            .validate()
+            .then(res => {
+              console.log(this.registerFormModel);
+              this.registerClickloading = true;
+              this.registerFormModel.username = this.registerFormModel.phone;
+              apiRegister(this.registerFormModel)
+                  .then(res => {
+                    this.registerClickloading = false;
+                    if (res.data.code == 0) {
+                      uni.showToast({
+                        title: '娉ㄥ唽鎴愬姛,鍗冲皢杩斿洖鐧诲綍椤�',
+                        icon: 'none',
+                        duration: 1000
+                      });
+                      setTimeout(() => {
+                        uni.redirectTo({ url: '/pages/login/login' });
+                      }, 1000);
+                    } else {
+                      this.$u.toast(res.data.msg ? res.data.msg : '娣诲姞澶辫触');
+                    }
+                  })
+                  .catch(err => {
+                    console.log('閿欒', err);
+                  });
+            })
+            .catch(err => {
+              console.log('err', err);
+              this.$u.toast('璇疯鑼冭緭鍏ュ唴瀹�');
+            });
 			},
 			// 鍗曢�夋浜嬩欢
 			groupChange(e) {},
@@ -485,11 +564,6 @@
 				) {
 					this.$refs.regesterFormRef.clearValidate();
 					this.beforeChangeValue = e;
-				}
-			},
-			jiaoYanPassword() {
-				if (this.registerFormModel.password != this.registerFormModel.confirmPassword) {
-					this.$u.toast('涓ゆ瀵嗙爜涓嶄竴鑷�');
 				}
 			},
 			// 涓婁紶鍥剧墖鏂规硶
@@ -618,4 +692,43 @@
 			}
 		}
 	}
-</style>
\ No newline at end of file
+  .intensity {
+    width: 100%;
+    margin-top: 10rpx;
+    .psdText {
+      font-size: 14px;
+      margin-right: 10px;
+    }
+
+    .line {
+      display: inline-block;
+      width: 70rpx;
+      height: 8rpx;
+      background: #d8d8d8;
+      border-radius: 6rpx;
+      margin-right: 16rpx;
+
+      &.low {
+        background: #f4664a;
+      }
+
+      &.middle {
+        background: #ffb700;
+      }
+
+      &.high {
+        background: #2cbb79;
+      }
+    }
+
+    .level {
+      margin: 0 32rpx 0 16rpx;
+    }
+
+    .warningtext {
+      color: #5a5a5a;
+      font-size: 24rpx;
+      margin-top: 10rpx;
+    }
+  }
+</style>

--
Gitblit v1.9.1