如本Meta Question中所述,Facebook 接受与我们的密码完全相反的大小写变体。例如:
1.- paSSw5ORD (Original password)
2.- PAssW5ord (Case altered to exact opposite, Capital->Small and vice-versa.)
3.- PaSSw5ORD (Only first letter's case altered)
如果第一个是用户输入的原始版本,如何获得第二个变体(或者在用户输入第二个版本时获得第一个)?这是我对此的看法。
<?php
$pass = "paSSw5ORD"; //Example password
$pass_len = strlen($pass); //Find the length of string
for($i=0;$i<$pass_len;$i++){
if(!(is_numeric($pass[$i]))){ //If Not Number
if($pass[$i]===(strtoupper($pass[$i]))){ //If Uppercase
$pass2 .= strtolower($pass[$i]); //Make Lowercase & Append
} else{ // If Lowercase
$pass2 .= strtoupper($pass[$i]); //Make Uppercase & Append
}
} else{ //If Number
$pass2 .= $pass[$i]; //Simply Append
}
}
//Test both
echo $pass."\r\n";
echo $pass2;
?>
但是如何让它处理带有特殊字符的密码(在标准英文键盘上都可能?
!@#$%^&*()_+|?><":}{~[];',./ (Space also)
这不适用于上述所有特殊字符。
if(preg_match('/^\[a-zA-Z]+$/', "passWORD")){
//Special Character encountered. Just append it and
//move to next cycle of loop, similar to when we
//encountered a number in above code.
}
我不是 RegEx 专家,那么如何修改上述 RegEx 以确保它处理所有上述特殊字符?