最新消息:

Axure中的密码强度校验(完美版)

Axure中级教程 Jorkin 423浏览

前言:

在上一篇 《Axure监听器之文本监听器》 中,我们介绍了如何同步密码星号和明文显示,虽然该文章的内容可能不是很深入,但也有读者提出了问题:“能不能增加一下功能——校验一下密码的强度?要求能够判断数字、大写字母、小写字母以及符号。”

如果是开发人员来实现此功能非常简单,但是在Axure中,默认情况下是无法使用正则表达式的,所以对于密码强度的校验就变得有些困难,我们先依次来分析每种情况:

  • 大写字母:
    • 校验大写字母很简单,只需要将密码转为小写形式(通过 .toLowerCase()方法) ,然后与原始密码进行比较,如果它们相等,则说明密码中没有大写字母。
  • 小写字母:
    • 同样地,将密码转为大写形式(通过 .toUpperCase()方法),然后与原始密码比较,如果相等说明没有小写字母。
  • 数字:
    • 由于数字只有10个,因此可以采用“暴力穷举”的方式来判断(是否包含0、是否包含1……)但是这种方法不够“优雅”!
  • 特殊字符:
    • 常见的可在键盘上直接输入的英文特殊字符在ASCII表里分了好几段:32-47、58-64、91-96、123-126都有,如果再用“暴力穷举”的方式实在是太野蛮了,而且对于中国人来说,密码里塞几个汉字或者全角字符好像也很正常,这种情况下穷举显然不现实,因此使用循环是比较好的办法。

诶?等等!!循环???都要用循环了,那前面的分析没就用了呀,直接用循环把每个字符都判断一下不就好啦?

——————— 所以……以上文字都不重要了[手动狗头] ———————

基础知识:

为了本篇文章,我还专门写了前置知识文章。如果你还不知道如何在Axure里使用循环,请先参考: 《如何在Axure中使用“循环”》

真·解决方案

老规矩,我们先看一下演示链接: https://usrsky.axshare.com/#id=thtdwf&g=1

这个演示密码强度校验实现了:

  1. 密码和明文的切换显示。
  2. 当密码为空时,提示“密码不能为空”
  3. 当密码少于8位时,提示“密码至少需要8位”
  4. 当密码中没有大写字母时,提示“没有大写字母”
  5. 当密码中没有小写字母时,提示“没有小写字母”
  6. 当密码中没有数字时,提示“没有数字”
  7. 当密码中没有符号时,提示“没有符号”
  8. 根据密码的强度不同,依次使用“红、橙、蓝、绿”四色提示增强用户体验
  9. 可以在任意位置插入、修改和删除字符,即使使用鼠标操作也能正确地进行校验。

基本教程

我们先从最最简单的开始一步一步来,准备好以下元件:

  • 一个文本框(命名:Password),用来输入密码。在测试时,可以先将其设置为文本,成功后再把输入类型改为“密码”。
  • 一个文本框(命名:Loop),用来做循环计数。
  • 一个文本字段(命名:Message),用于反馈信息。
  • 一个“校验密码强度”按钮(命名:校验密码强度)。
  • 四个复选框(分别命名:大写、小写、数字、字符),用于来记录对应类型是否存在。

首先,我们需要在“校验密码强度”按钮上编写交互事件:

由于很多时候需要使用到Loop里的文本值,所以可着物尽其用的原则,因此我们将尽可能多的交互事件都写在Loop文本框上,分别使用“尺寸改变时移动时选中或切换选中时”吧:

Loop的“尺寸改变时”,用来做循环的判断:

Loop的“移动时”,用来判断每一个字符的类别。其中pwd变量是Password元件的文本:

其中“其它”的判断稍微有点复杂,需要判断好几个区间。(注意右上角:符合任意条件)

Loop的“选中或取消选中时”,用于做最终总结:

这样一个基本的密码强度校验功能就做好啦。

进阶教程

接下来让我们进行一些进阶教程。对于之前实现的功能,还有一些可以优化的方面:

  • 添加明码和密文转换功能。
  • 在符号范围判断时应该考虑全角符号和双字节文字。
  • 可以限制每种类型字符的最少出现次数等。
  • 为避免影响效率,可以限制密码框中输入文本的长度。
  • 如果四个复选框都被选中,则无需再对后续字符做检查,应该增加相应判断。
  • 应该增加一个可视化的强度展示,提升用户体验。
  • 其它还有很多我没想到的,可以评论区补充。

前个都几个好解决,我们将重点介绍如何实现可视化强度展示:

在前面做好的原型基础上,准备一个动态面板,包含5个状态,分别为(空、25%红色、50%橙色、75%蓝色、100%绿色)

在“校验密码强度”按钮的点击事件中,增加一步用于重置动态面板状态的操作。

顺便将循环逻辑优化一下:

在字符类型的判断上删除全部的区间判断,允许全角符号及双字节文字:

在最终判断时加入对动态面板的改变,这里不需要判断当前状态,直接下一项即可:

最后,预览我们完成的成果。

总结

使用循环可以对密码文本的全部字符进行类型判断,无论在何处增加、修改或删除。为提升用户体验,我们还可以增加一些优化功能,如文本框转换、符号范围限制、最少个数限制等,并且通过可视化强度展示让用户更直观地了解密码强度。

如果觉得我的教程做的不错呢,欢迎关注、收藏、转发、捐赠,谢谢。

原文链接:Axure中的密码强度校验(完美版)

转载请注明:最InのAxure » Axure中的密码强度校验(完美版)