前言:
在上一篇 《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
这个演示密码强度校验实现了:
- 密码和明文的切换显示。
- 当密码为空时,提示“密码不能为空”
- 当密码少于8位时,提示“密码至少需要8位”
- 当密码中没有大写字母时,提示“没有大写字母”
- 当密码中没有小写字母时,提示“没有小写字母”
- 当密码中没有数字时,提示“没有数字”
- 当密码中没有符号时,提示“没有符号”
- 根据密码的强度不同,依次使用“红、橙、蓝、绿”四色提示增强用户体验
- 可以在任意位置插入、修改和删除字符,即使使用鼠标操作也能正确地进行校验。
基本教程
我们先从最最简单的开始一步一步来,准备好以下元件:
- 一个文本框(命名:Password),用来输入密码。在测试时,可以先将其设置为文本,成功后再把输入类型改为“密码”。
- 一个文本框(命名:Loop),用来做循环计数。
- 一个文本字段(命名:Message),用于反馈信息。
- 一个“校验密码强度”按钮(命名:校验密码强度)。
- 四个复选框(分别命名:大写、小写、数字、字符),用于来记录对应类型是否存在。
首先,我们需要在“校验密码强度”按钮上编写交互事件:
由于很多时候需要使用到Loop里的文本值,所以可着物尽其用的原则,因此我们将尽可能多的交互事件都写在Loop文本框上,分别使用“尺寸改变时、移动时、选中或切换选中时”吧:
Loop的“尺寸改变时”,用来做循环的判断:
Loop的“移动时”,用来判断每一个字符的类别。其中pwd变量是Password元件的文本:
其中“其它”的判断稍微有点复杂,需要判断好几个区间。(注意右上角:符合任意条件)
Loop的“选中或取消选中时”,用于做最终总结:
这样一个基本的密码强度校验功能就做好啦。
进阶教程
接下来让我们进行一些进阶教程。对于之前实现的功能,还有一些可以优化的方面:
- 添加明码和密文转换功能。
- 在符号范围判断时应该考虑全角符号和双字节文字。
- 可以限制每种类型字符的最少出现次数等。
- 为避免影响效率,可以限制密码框中输入文本的长度。
- 如果四个复选框都被选中,则无需再对后续字符做检查,应该增加相应判断。
- 应该增加一个可视化的强度展示,提升用户体验。
- 其它还有很多我没想到的,可以评论区补充。
前个都几个好解决,我们将重点介绍如何实现可视化强度展示:
在前面做好的原型基础上,准备一个动态面板,包含5个状态,分别为(空、25%红色、50%橙色、75%蓝色、100%绿色)
在“校验密码强度”按钮的点击事件中,增加一步用于重置动态面板状态的操作。
顺便将循环逻辑优化一下:
在字符类型的判断上删除全部的区间判断,允许全角符号及双字节文字:
在最终判断时加入对动态面板的改变,这里不需要判断当前状态,直接下一项即可:
最后,预览我们完成的成果。
总结
使用循环可以对密码文本的全部字符进行类型判断,无论在何处增加、修改或删除。为提升用户体验,我们还可以增加一些优化功能,如文本框转换、符号范围限制、最少个数限制等,并且通过可视化强度展示让用户更直观地了解密码强度。
如果觉得我的教程做的不错呢,欢迎关注、收藏、转发、捐赠,谢谢。
原文链接:Axure中的密码强度校验(完美版)
转载请注明:最InのAxure » Axure中的密码强度校验(完美版)