آموزش ساخت فرم ثبت نام با php

daskhatmin فواد طهماسبی
110,157 بازدید
آموزش ساخت فرم ثبت نام با php

در این آموزش می خوام به شما نحوه ساختن سیستم ثبت نام با php در وبسایت رو آموزش بدم. اگرچه شاید برخی افراد فکر کنن کار سختی هست اما در این آمورش خواهند دید که ساده تر از چیزی است که فکر می کنن و با کمی کد نویسی ساده امکان پذیره . در عمل شما نیاز به یک جدول و یک سرور php دارید .  در این آموزش شما مطالب زیر رو یاد می گیرید:

  1. نحوه ایجاد فایل نصب برای اسکریپت
  2. نحوه اتصال به پایگاه داده
  3. نحوه ثبت نام کاربر
  4. ذخیره اطلاعات در پایگاه داده
  5. ورود یا همون login کاربر
  6. نحوه شناسایی کاربر در صفحات
  7. نحوه خروج از سیستم

قبل از شروع کار، شما به یک پایگاه داده نیاز دارید تا در برنامه از آن استفاده کنید. در ابتدا شما می توانید یک پایگاه داده با نام myDB ایجاد کنید در این پایگاه داده شما نیاز به یک جدول دارید . در این جدول نیز باید اطلاعات زیر وجود داشته باشند :

  1. (userid (auto increment
  2. username
  3. password
  4. email address

ساختار فایل install.php

حالا ما ساختار کلی از جدول را داریم ، اکنون می توانیم دستورات زیر را در mysql  یا از phpmyadmin اجرا کنیم تا جدول ساخته شود. دستورات یا کدهای لازم برای ساخت جدول “usersystem” در پایگاه داده”myDB” رو می تونید در سطر بعدی ببینید :

CREATE TABLE myDB.usersystem (
userid INT(5) NOT NULL AUTO_INCREMENT , 
username VARCHAR( 50 ) NOT NULL , 
password VARCHAR( 32 ) NOT NULL , 
email VARCHAR( 50 ) NOT NULL , 
PRIMARY KEY ( userid )
)

کدهای مربوط به نصب پایگاه داده، قبل از هر چیز ابتدا باید پایگاه داده ایجاد شده و جداول مربوط نیز ساخته شود. فایل زیر این کار را میکند:

<?php
//نصب پایگاه داده

include('index.php');
// establish a connection to the database server
if(!$connection = mysqli_connect('localhost', 'root', '')) {
    die("ERROR: Can't Connect To Database Server;" . mysqli_error($connection));
}
mysqli_query($connection, "CREATE DATABASE myDB");
if(!mysqli_select_db($connection, 'myDB')) {
    mysqli_close($connection);
    die("ERROR: Can't Select Database;" . mysqli_error($connection));
}
mysqli_set_charset($connection, 'utf8');
$query = "
CREATE TABLE IF NOT EXISTS usersystem ( 
    userid INT(5) NOT NULL AUTO_INCREMENT , 
    username VARCHAR( 50 ) NOT NULL , 
    password VARCHAR( 32 ) NOT NULL , 
    email VARCHAR( 50 ) NOT NULL , 
    PRIMARY KEY ( userid )
)";

$result = mysqli_query($connection, $query);
if (!$result) {
    echo'>> Can\'t Creat Users Table < < '.  mysqli_error($connection).'<br />';
} else {
    echo '[ Users Table Created Successfully ] <br />';
}
?>
<br><hr><a href="index.php">Index Page</a><br>

ساختار فایل db.php

اولین فایل ، فایل ساختار ما خواهد بود که در این فایل function ها و دستورات اتصال ما به پایگاه داده قرار دارد. این فایل بعدا در ابتدای تمامی صفحات توسط include قرار داده می شود.

ابتدا ما ()sesssion_start را در خط اول می نویسیم . این دستور ما رو برای تشخیص کاربر وارد شده کمک خواهد کرد. در کل به عبارتی  session  برای هر کاربر یک آی دی ایجاد می کنه تا توسط اون کاربران در سیستم شناخته بشن تقریبا مانند cookie  در مرورگر برای وبسایت .

این کد به شکل زیر استفاده میشه :

<?php 
   session_start();
?>

در مرحله بعد باید با پایگاه داده اتصال برقرار کنیم . از توابع ()mysqli_connect و ()mysqli_select_db  برای اینکار استفاده می کنیم . این دو خط  هم به صورت زیراستفاده میشن :

<?php
  session_start();
  $connection = mysqli_connect("localhost", "username of your database", "password of database"); 
  mysqli_select_db($connection, "myDB");
?>

حالا تابع ()user_login رو درست می کنیم که کاربر خواست وارد بشه از اون استفاده کنیم. کدهای لازم برای ورود کاربر و کدهای لازم برای بررسی نام کاربری و کلمه عبور رو می تونید در ادامه ببینید :

<?php
  session_start();
  $connection = mysqli_connect("localhost", "root", "");
  mysql_select_db($connection, "myDB"); 

  //تابع بررسی صحت کاربر
function user_login ($username, $password) { 
  $username = mysqli_real_escape_string($connection, $username); 
  // چون پسورد در پایگاه داده به صورت کد شده قرار دارد ما نیز ابتدا پسورد دریافتی را کد کرده با پسورد موجود در پایگاه داده بررسی میکنیم
  $password = md5($password);
  $result = mysqli_query($connection, "SELECT * FROM usersystem WHERE username = '".$username."' AND password = '".$password."' LIMIT 1"); 
  $rows = mysqli_num_rows($result); 
  if ($rows<=0 ){ 
      echo "Incorrect username/password"; 
    }
  else { 
  // اگر کاربر تایید شد از طریق نشست ورود کاربر را مشخص میکنیم.
     $_SESSION['username'] = true;
	 echo "<a href='adminpage.php'>you're login successfuly [Go To ADMINPAGE]</a><br><br>";
    } 
 }
?>

حالا میریم سراغ قسمت ثبت نام کاربر :

ساختار فایل register.php

حالا ما نیاز به یک صفحه داریم تا کاربر بتونه ار اونجا ثبت نام خودش رو انجام بده. این فایل شامل کدهای HTML و PHP است که به صورت زیر است:

<html>
  <form action="register.php" method="post">
     Username: <input name="username" type="text" />
     Password: <input type="password" name="password" />
     Email: <input name="email" type="text" />
     <input type="submit" value="Submit" />
  </form>
</html>

حال نیاز داریم اطلاعات دریافت شده از کاربر رو  پاکسازی و سپس در پایگاه داده ثبت کنیم . در این کد ابتدا پر بودن فیلدهای username ، password و email بررسی می شود و سپس از تکراری نبودن username اطمینان حاصل می کند. کد زیر را ابتدای فایل register.php  و قبل از کدهای Html قرار دهید .

<?php 
// فراخوانی منوی بالا
include('index.php');
// فراخوانی فایل دیتابیس
include("db.php"); 
if(isset($_POST['username']) && isset($_POST['password']) && isset($_POST['email'])){ 
	$username = mysqli_real_escape_string($connection, $_POST['username']); 
	$email = mysqli_real_escape_string($connection, $_POST['email']); 
	$password = md5($_POST['password']); 
	$sql = mysqli_query($connection, "SELECT username FROM usersystem WHERE username = '".$username."'");
	if(mysqli_num_rows($sql)>0){ 
		die("Username taken."); 
	} 
	mysqli_query($connection, "INSERT INTO usersystem(username, password, email) VALUES('$username', '$password', '$email')") or die (mysqli_error($connection)); echo "Account created."; 
} 
?>

ساختار فایل login.php

و در آخر کدهای صفحه ورود. دراین فایل نیاز به یک فرم داریم تا username و password را از کاربر دریافت کرده و پس ازاعتبار سنجی کاربر مجوز لازم برای ورود داده شود.

<?php
include('index.php');
include("db.php"); 
if(isset($_POST['username']) && isset($_POST['password'])){ 
// تایید ورود کاربر از طریق تابعی که در فایل دیتابیس نوشتیم    
	user_login($_POST['username'], $_POST['password']); 
} 
?>
<html>
  <form action="login.php" method="post">
     Username: <input name="username" type="text" />
     Password: <input type="password" name="password" />
	 <input type="submit" value="submit" />
  </form>
</html>

کد زیر را باید در ابتدای تمامی صفحات وارد کنید تا بوسیله آن مجوز دسترسی کاربر بررسی شود:

<?php 
include('index.php');
include "db.php";
if(!$_SESSION['username']){
// تغییر مسیر کاربر در صورتی که وارد یا لاگین نشده است
  header('location: ../login.php');
  exit();
}
?>

ساختار فایل logout.php

<?php
// خروج از سیستم و فالس کردن نشست
session_start();
$_SESSION['username'] = false;
echo "<a href='adminpage.php'>you're log Out successfuly [Go To ADMINPAGE]</a><br><br>";
?>

این آموزش به صورت ساده بیان شده و برای استفاده در پروژه های تجاری و وبسایت هایی که نیاز به امنیت زیادی دارن توصیه نمی شود.

 

php-register-form

پیش نمایش فایلهای آموزش

دانلود “فرم ثبت نام با php”
نسخه 3.0.0 10 بار دانلود شده 5 KB

 

فایل بالا با توابع mysqli پیاده سازی و تست شده است.

daskhatmin

فواد طهماسبی

فواد طهماسبی هستم، موسس وبسایت آموزشی دسخط. مهندسی نرم افزار خوندم و چندین سال تجربه کاری مرتبط با تکنولوژیهای توسعه وب دارم. علاقمند به ایده پردازی و توسعه کسب و کارهای اینترنتی هستم.

121 دیدگاه برای “آموزش ساخت فرم ثبت نام با php”

  1. حسنا گفت:

    سلام.در فرم ثبت نام طراحی شده با php من می خواستم ایمیل منحصر به فرد باشد یعنی کسی که قبلا ثبت نام کرده با همان ایمیل دوباره نتواند ثبت نام کند. اما در کد نویسیش مشکل دارم در صورت امکان راهنمایی بفرمایید.ممنونم

  2. persianwikileaks گفت:

    باتشکر

  3. ساحل گفت:

    سلام
    من وقتی از توابع mysql_ connect برای اتصال به پایگاه داده استفاده میکنم . موقع اجرا برنامه خطا میده .
    و باید حتما از توابع mysqli_connect. استفاده کنم .
    ممنون میشم راهنماییم کنید تا موقع اجرای توابعی که با mysql نوشته میشه خطا نده !

  4. zohre گفت:

    با عرض سلام و خسته نباشید خدمت شما
    من یه سوال در این رابطه داشتم می خواستم بدونم که من چه جوری می توان در نرم افزار dreamweave که می خواهم برنامه php بنویسیم برای قسمت loginآن بخواهیم تا قبل از وارد شدن کاربر دکمهlog out غیر فعال شود و به محض ورود کاربر دکمه log out فعال شود.و فرم log in غیر فعال شود اگهر میشه در این رابطه به من کمک کنید
    واگر میشه جواب را حتما به ایمیلم ارسال کنید.
    با تشکر اسلامی

  5. web گفت:

    سلام
    من یه سایت در حال حاضر دارم که در ومپ و در قسمت لوکال هاست اجرا گرفتم
    اگر بخواهم از این کدهای شما اضافه کنم باید به کدام قسمت سایت اضافه کنم ؟

  6. امیر محمد گفت:

    با سلام
    و با تشکر از آموزش خوبتان
    اگه ممکنه متن زیر را برایم توضیح بدهید( در php )

    با تشکر و سپاس

  7. مرضیه گفت:

    من هنگام نصب MySQL 5.5 به کادر انتهایی که مرحله نصب برنامه(processing fconfiguration) میمونه و انتهای نوارعنوانش not responding میاد و ادامه نمیده .لطفا راهنماییم کنید به این برنامه خیلی نیاز دارم

  8. لادن گفت:

    سلام
    چرا لاگینش کار نمی کنه ؟
    تو دیتابیس ذخیره می شه ولی خطای
    invalid user pass میده

  9. جمشید طهماسبی گفت:

    سلام وقت بخیر…
    من میخوام با PHP اطلاعات نام ونام خانوادگی و نام کاربری و پسورد و جنسیت را از کاربر بگیرد.
    باید اعتبارسنجی انجا بدهد(جلوگیری از تزریق کدهای جاوا اسکریپت و HTML کنترل خالی نبودن ورودی ها).
    اگر اعتبارسنجی نتیجه اش درست است در همان فایل اطلاعات وارد شده به کاربر نمایش داده شود.
    خیلی ممنونتون میشم اگه زود جواب بدید…

  10. majid گفت:

    سلام خسته نباشید.
    من در قسمت mysql_num_rows هر چد باری که مینویسم ارور میده و میگه بولینه باید چی کار کنم در ضمن من کد شما رو منظورم نیست یک کد دیگه خودم نوشتم این مشکل رو داره در ضمن لطفا با ایمیلم تماس بگیرید.

دیدگاه‌های بیشتر

کد HTMLCSSJavaScriptPHP