"유효한 문자 배열"에서 문자 배열을 생성하면 최종 결과는 임의의 문자 집합이지만 순서는 같습니다. 예를 들어, 나는 34579abopxzBCJMSTXY를 얻을 것이다.무작위 배열이 작동하지 않습니다.
include('db.php');
//$num= mt_rand();
$veces = $_POST['veces'];
$equipos = $_POST['equipos'];
$description = $_POST['description'];
$salt = "oijahsfdapsf80efdjnsdjp";
function get_result(){
$valid_chars=array("0","1", "2", "3", "4", "5", "6", "7", "8", "9"
, "a", "b", "c", "d", "e", "f", "g", "h", "j", "k", "m", "n", "p", "q", "r", "s", "t", "u", "v", "w", "x", "y", "z"
, "A", "B", "C", "D", "E", "F", "G", "H", "J", "K", "M", "N", "P", "Q", "R", "S", "T", "U", "V", "W", "X", "Y", "Z");
$result=array_rand($valid_chars, 20); //Cantidad de Caracteres
$result_str='';
foreach ($result as $value)
{
$result_str.=$valid_chars[$value];
}
return $result_str;
}
$results=array();
for ($i=0; $i<=2000; $i++)
{
array_push($results, get_result());
}
$results=array_unique($results);
$cont=0;
$results_str='';
foreach ($results as $value)
{
$cont++;
$results_str.=$value.'
';
// Add some salt
$salt = "oijahsfdapsf80efdjnsdjp";
$salt .= $value; //oijahsfdapsf80efdjnsdjp_Plus_RandomString
$value = $salt; //Change the RandomString to contain our new salted pass
$value = md5($value); //(cannot be reversed on a rainbow table as we have a secret salt also..)
$db = new Database();
$ins_query = "INSERT INTO licensing(license, computers, state, description) VALUES('{$value}', '{$equipos}', '2', '{$description}')"; // query to insert value
$db->query($ins_query);
if ($cont>=$veces)
{
break;
}
}
echo '<pre>';
echo $results_str;
echo '</pre>';
PHP 정보 버전 5.3.3
출력 예 :
1389adehtvwCEKMNQSUY
15bgmnpruwzAEFHTUVWY
159bcenqrswxzFKMNQUX
35bchstvwxyzEGKNQSUV
124789defgmvyDEHKNRT
5abefhjprsuwxCDMPQXY
암호화 목적으로 MD5 사용을 중단 할 때입니다. 거기에 훨씬 더 나은 대안이 있습니다. 그 중 하나를 대신 사용하십시오. –