Ben $ _POST ayarlı değilse ilk kayıt formunu gösterecek olan, hepsi tek bir kayıt / giriş komut bir yapıyorum. O, ancak gerekli alanlar dolu değilseniz, bu, tekrar sayfaya yeniden ayar $ 'POST yönlendirir. Tüm alanları doldurun eğer düğme $ 'POST göndermek ["login"] adı ayarlanırsa, daha sonra, formu giriş onaylar ve bir sayfa alışveriş sepetine kullanıcı yönlendirme ya da metin bloğunu, setleri saklamak için geri. ["Kayıt"] düğmesi $ 'POST göndermek ayarlanırsa, daha sonra kullanıcı kayıt olmak istiyor ve bir ekleme sorgusu yapılmış ve teslim edilmiştir. Bu sorgu etkilenen satır döndürürse kullanıcı zaten kayıtlı ise, o zaman komut dosyası denetler. Eğer öyleyse, onları kaydeder ve normal oturum başına onları yönlendirme sayfayı gösterir. Script etkilenen 1 satır döndürür Aksi takdirde, o zaman ben insert (sorguları başarısız olursa ben komut mola) başarılı olduğunu varsayalım.
Eğer giriş vurursan eserlerinde açılıyor ve gerekli bir alan kaçırırsanız yönlendirmeleri çalışır, ama o kadar. Ben sorun göremiyorum ve ben hiç hata olsun - Ben sadece diğer koşullar durumunda boş bir ekran olsun. Bu kod büyük bir yığın var, korkarım ...
<?php
if(!$_POST) {
//hasn't seen the registration form
//display registration form
$display_block = "
<form method=\"POST\" action=\"".$_SERVER["PHP_SELF"]."\">
<p>Please fill in the registration field (required fields marked with <span class=\"req\"><</span>)<br />
First name: <input type=\"text\" name=\"f_name\" size=\"25\" maxlength=\"50\" /><span class=\"req\"><</span><br />
Last name: <input type=\"text\" name=\"l_name\" size=\"25\" maxlength=\"50\" /><span class=\"req\"><</span><br />
Address: <input type=\"text\" name=\"address\" size=\"50\" maxlength=\"150\" /><br />
Town: <input type=\"text\" name=\"town\" size=\"50\" maxlength=\"150\" /><br />
City: <input type=\"text\" name=\"city\" size=\"50\" maxlength=\"150\" /><br />
Post Code: <input type=\"text\" name=\"postcode\" size=\"10\" maxlength=\"10\" /><br />
Username: <input type=\"text\" name=\"username\" size=\"25\" maxlength=\"25\" /><span class=\"req\"><</span><br />
Confirm username: <input type=\"text\" name=\"usernameConfirm\" size=\"25\" maxlength=\"25\" /><span class=\"req\"><</span><br />
Password: <input type=\"password\" name=\"password\" size=\"25\" maxlength=\"25\" /><span class=\"req\"><</span><br />
Confirm password: <input type=\"password\" name=\"passwordConfirm\" size=\"25\" maxlength=\"25\" /><span class=\"req\"><</span><br />
<br />
<input type=\"submit\" name=\"register\" value=\"Register\" /><br /><br />
Already a member? <input type=\"submit\" name=\"login\" value=\"Login\" />
</p>";
} else if ((!isset($_POST["username"])) || (!isset($_POST["usernameConfirm"])) || (!isset($_POST["password"])) || (!isset($_POST["passwordConfirm"]))) {
//hasn't filled out all the fields
header("Location: ".$_SERVER["PHP_SELF"]."");
exit;
} else if($_POST["login"]) {
//user is logging in, so connect to server and select database, check they are registered and their details are right
$mysqli = mysqli_connect(hostname,username,pass,dbname);
//create and issue the query
$sql = "SELECT f_name, l_name FROM auth_users WHERE username='".$_POST["username"]."' AND password=PASSWORD('".$_POST["password"]."')";
$sql_res =mysqli_query($mysqli, $sql) or die(mysqli_error($mysqli));
//get the number of rows in the result set; should be 1 if a match
if(mysqli_num_rows($sql_res) == 1) {
//if authorized, get the values of f_name, l_name
while($info = mysqli_fetch_array($sql_res)) {
$f_name = stripslashes($info["f_name"]);
$l_name = stripslashes($info["l_name"]);
}
//set authorization cookie
setcookie("auth", "1", 0, "/", "sinaesthesia.co.uk", 0);
//create display string
$display_block = "<p>".$f_name." ".$l_name." is authorized.</p>
<p>You are now logged in.</p>
<a href=\"basket.php5\">View Basket</a> | <a href=\"home.php5\">Continue Shopping</a>";
} else if($_POST["register"]) {
//connect to db and issue registration query
$mysqli = mysqli_connect(hostname,username,pass,dbname);
$register_sql = "INSERT INTO aromaMaster (username, password, date_registered) VALUES ('".$_POST["username"]."',PASSWORD('".$_POST["password"]."'),now())";
$register_res = mysqli_query($mysqli, $register_sql) or die(mysqli_error($mysqli));
if (mysqli_num_rows($register_res) != 1) {
//registration failed - perhaps duplicate account
$check_sql = "SELECT username, password FROM aromaMaster WHERE username='".$_POST["username"]."' AND password=PASSWORD('".$_POST["password"]."')";
$check_res = mysqli_query($mysqli, $check_sql) or die(mysqli_error($mysqli));
if(mysqli_num_rows($check_res) == 1) {
//already a member
//set cookie
//set authorization cookie
setcookie("auth", "1", 0, "/", "sinaesthesia.co.uk", 0);
$display_block = "
<p>You are already registered.</p>
<a href=\"basket.php5\">View Basket</a> | <a href=\"home.php5\">Continue Shopping</a>";
}
} else {
//success
$display_block = "
<p>You are registered!</p>
<a href=\"basket.php5\">View Basket</a> | <a href=\"home.php5\">Continue Shopping</a>";
}
}
mysqli_close($mysqli);
}
?>
<html>
<head>
<title>Login / Register</title>
</head>
<body>
<?php echo "$display_block"; ?>
</body>
</html>