私はほとんどそこにいますが、何かが欠けています.My PHPアプリ:
1) ユーザーがサーバーに要求している
2) サーバーは長い一意の文字列を生成し、DB に存在するかどうかを確認します。YES の場合は (存在しないまで) 再度生成し、NO の場合は DB に追加して終了します。すべてのロジックは単一のリクエストで実行する必要があります。つまり、生成された文字列が存在する場合、ユーザーはページをリクエストまたは更新しないでください。
私はYESの部分で立ち往生しています。
私のコード(免責事項:私は次のコードの一部を所有していません)
<?php
class genPass
{
private $db;
function __construct() {
$this->db=new mysqli('localhost', 'user', 'pass', 'db');
$this->db->set_charset("utf8");
$this->db->autocommit(FALSE);
}
function __destruct() {
$this->db->close();
}
function isUsed($uid)
{
$stmt=$this->db->query("SELECT * FROM id WHERE udid='".$uid."'")or die($this->db->error);
while($stmt->num_rows <1) {
$newnum = $this->generateStrongPassword();
$newcheck=$this->db->query("SELECT * FROM id WHERE udid='".$newnum."'")or die($this->db->error);
if ($newcheck->num_rows >= 1) {
echo $newnum . " exists! \n"; <- WHAT TO DO IF EXISTS?WHICH PART OF THE SCRIPT SHOULD I RUN AGAIN
} else {
$this->db->query("INSERT INTO id (udid) VALUES ('".$newnum."')")or die($this->db->error);
echo "$newnum - CAN ISNERT@!@!@";
break;
}
}
}
public function generateStrongPassword($length = 3, $add_dashes = false, $available_sets = 'lu')
{
$sets = array();
if(strpos($available_sets, 'l') !== false)
$sets[] = 'ab';//'abcdefghjkmnpqrstuvwxyz';
if(strpos($available_sets, 'u') !== false)
$sets[] = 'AB';//'ABCDEFGHJKMNPQRSTUVWXYZ';
if(strpos($available_sets, 'd') !== false)
$sets[] = '23456789';
if(strpos($available_sets, 's') !== false)
$sets[] = '!@#$%&*?';
$all = '';
$password = '';
foreach($sets as $set)
{
$password .= $set[array_rand(str_split($set))];
$all .= $set;
}
$all = str_split($all);
for($i = 0; $i < $length - count($sets); $i++)
$password .= $all[array_rand($all)];
$password = str_shuffle($password);
if(!$add_dashes)
return $password;
$dash_len = floor(sqrt($length));
$dash_str = '';
while(strlen($password) > $dash_len)
{
$dash_str .= substr($password, 0, $dash_len) . '-';
$password = substr($password, $dash_len);
}
$dash_str .= $password;
return $this->$dash_str;
}
}
$obj = new genPass;
$ran=$obj->generateStrongPassword();
$obj->isUsed($ran);
?>