时间:2021-05-22
客户系统升级,要求用户密码符合一定的规则,即:包含大小写字母、数字、符号,长度不小于8,于是先用python写了个简单的测试程序:
在写解决方案前,列一下
python正则表达式中的特殊字符:
^ 表示匹配的字符必须在最前边
$ 表示匹配的字符必须在最后边
* 匹配* 前面的字符0次或n次
+ 匹配+ 前面的字符1次或n次
? 匹配?前面的字符0次或1次
. (小数点)匹配除换行符外的所有字符
(x) 匹配x并记录匹配的值
x|y 匹配x或者y
{n} 这里n是一个正整数。匹配前面的n个字符
{n,} 这里n是一个正整数。匹配至少n个前面的字符
{n,m} 这里n和m都是正整数。匹配至少n个、最多m个前面的字符
[xyz] 字符列表,匹配表中的任一字符,可以通过连接字符 - 指出字符范围,如 [a-z] 表示所有小写字符
[b] 匹配一个空格
b 匹配一个单词的分界线,比如一个空格
B 匹配一个单词的非分界线
re模块匹配规则(re.match函数的第三个参数):
re.IGNORECASE 忽略文中的大小写
re.LOCALE 处理字符集本地化
re.MULTILINE 是否支持多行匹配
re.DOTALL 匹配一些特殊标记,例如使用.匹配\n等字符
re.VERBOSE 忽略正则表达式中的空格或者换行等字符
re.UNICODE 使用Unicode编码
#encoding=utf-8#-------------------------------------------------------------------------------# Name: 模块1# Purpose:## Author: Administrator## Created: 10-06-2014# Copyright: (c) Administrator 2014# Licence: <your licence>#-------------------------------------------------------------------------------import redef checklen(pwd): return len(pwd)>=8def checkContainUpper(pwd): pattern = re.compile('[A-Z]+') match = pattern.findall(pwd) if match: return True else: return Falsedef checkContainNum(pwd): pattern = re.compile('[0-9]+') match = pattern.findall(pwd) if match: return True else: return Falsedef checkContainLower(pwd): pattern = re.compile('[a-z]+') match = pattern.findall(pwd) if match: return True else: return Falsedef checkSymbol(pwd): pattern = re.compile('([^a-z0-9A-Z])+') match = pattern.findall(pwd) if match: return True else: return Falsedef checkPassword(pwd): #判断密码长度是否合法 lenOK=checklen(pwd) #判断是否包含大写字母 upperOK=checkContainUpper(pwd) #判断是否包含小写字母 lowerOK=checkContainLower(pwd) #判断是否包含数字 numOK=checkContainNum(pwd) #判断是否包含符号 symbolOK=checkSymbol(pwd) print(lenOK) print(upperOK) print(lowerOK) print(numOK) print(symbolOK) return (lenOK and upperOK and lowerOK and numOK and symbolOK)def main(): if checkPassword('Helloworld#123'): print('检测通过') else: print('检测未通过')if __name__ == '__main__': main()平时用正则不多,不知道怎么写一个正则满足要求,用了比较笨的办法,谁知道一句正则检验的请赐教!
我们再来看一个稍微复杂些的 检测邮箱名及密码验证
代码:
main.py
# coding=gbk import re def ProcessMail(inputMail): isMatch = bool(re.match(r"^[a-zA-Z](([a-zA-Z0-9]*\.[a-zA-Z0-9]*)|[a-zA-Z0-9]*)[a-zA-Z]@([a-z0-9A-Z]+\.)+[a-zA-Z]{2,}$", inputMail,re.VERBOSE)); if isMatch: print ("邮箱注册成功。"); else: print ("邮箱注册失败。"); return isMatch; def ProcessPassword(inputPassword): #处理正则表达式 isMatch = bool(re.match(r"[a-zA-Z0-9]{8}",inputPassword,flags=0)); #用type的三位表示数字type[0],小写字母type[1],大写字母type[2]是否都具备 if isMatch: type = [False,False,False] for i in range(0,8): temp = inputPassword[i] if ord(temp) >= ord('0') and ord(temp) <= ord('9'): type[0] = True; elif ord(temp) >= ord('a') and ord(temp) <= ord('z'): type[1] = True; elif ord(temp) >= ord('A') and ord(temp) <= ord('Z'): type[2] = True; for i in type: if i is False: isMatch = False; break; #处理是否有重复的字符出现 if isMatch: for i in range(0,7): temp = inputPassword[i]; for j in range(i + 1,8): if inputPassword[j] == temp: isMatch = False; break; if isMatch: print ("密码注册成功。"); else: print ("密码注册失败。"); return isMatch; if __name__ == '__main__': mailState = False; while mailState is False: inputMail = input("输入邮箱: "); mailState = ProcessMail(inputMail); print ("\n"); # passwordState = False; while passwordState is False: inputPassword = input("输入密码: "); passwordState = ProcessPassword(inputPassword); print ("\n");输出:
密码的测试也满足需求,不一一列举
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
ThinkPHP3.1版增加了表单提交的字段合法性检测,可以更好的保护数据的安全性。这一特性是3.1安全特性中的一个重要部分。表单字段合法性检测需要使用crea
IP合法性校验是开发中非常常用的,看起来很简单的判断,作用确很大,写起来比较容易出错,今天我们来总结一下,看一下3种常用的IP地址合法性校验的方法。不使用正则表
javascript正则表达式验证IP地址的端口合法性if(!(/^[1-9]\d*$/.test(port)&&1
一、python校验IP地址合法性执行效果:python代码:复制代码代码如下:[root@yangpython]#vicheck_ip.py#!/usr/bi
python是不带静态检查的动态语言,有时候需要在调用函数时保证参数合法。检查参数合法性是一个显著的切面场景,各个函数都可能有这个需求。但另一方面,参数合法性是