我正在解决一个挑战算法,并被告知要创建一个密码验证器来检查:
我编写了这个函数来验证它:
<?php
function Validate($input){
$length = strlen($input);
if($length < 6 || $length > 20){
return 'False';
}
if( !preg_match('/[0-9]+/', $input) ){
return 'False';
}
if( !preg_match('/[A-Z]+/', $input) ){
return 'False';
}
if( !preg_match('/[a-z]+/', $input) ){
return 'False';
}
return 'True';
}
?>挑战报告说,我的功能失败了四个测试用例中的两个(4)。请有人能帮我提供任何可能的测试用例来指出我的功能缺失了什么吗?
发布于 2018-09-07 10:27:16
正如注释已经指出的,您正在从函数返回字符串,而不是布尔值。但是,您不需要这样膨胀的逻辑来检查密码要求。我建议在这里使用preg_match和一个正则表达式:
function Validate($input) {
return preg_match("/(?=.*[A-Z])(?=.*[a-z])(?=.*[0-9]).{6,20}/", $input));
}
演示
顺便说一句,当前功能中的逻辑正在工作。,我不明白为什么代码测试会有问题。也许您的返回类型不应该是字符串。
发布于 2018-09-07 11:10:08
此Validate函数将返回一个真值,而不考虑输入--因此,任何具有有效密码的测试都将成功,任何具有无效密码的测试都将失败。
关于在PHP中被认为是正确和错误的细节:http://fi2.php.net/manual/en/language.types.boolean.php#language.types.boolean.casting
https://stackoverflow.com/questions/52220495
复制相似问题