Когда я генерирую массив символов из «допустимого массива символов», конечным результатом является случайный набор символов, но в порядке. Например, я получу 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 для криптографических целей. Есть намного лучшие альтернативы. Вместо этого используйте один из них. –