دسته بندی
دسترسی سریع
آموزش ساخت پنل ورود و خروج سایت با PHP و MySQL
سشن (Session) یا نشست چیست و چه کاربردی دارد؟
ساخت دیتابیس، جدول، ستون ها و درج نمونه اطلاعات
ایجاد فولدری با نام php-mysql-signin
تنظیم اطلاعات اتصال به دیتابیس در فایل config.php
فرم HTML جهت ورود و خروج در فایل index.php
بررسی وضعیت ورود کاربر با فایل login.php
برقراری نشست (Session) در پنل کاربری با فایل panel.php
پایان نشست و خروج از سایت با فایل logout.php
دانلود نمونه فایل های آموزش
سشن (Session) یا نشست چیست و چه کاربردی دارد؟
ساخت دیتابیس، جدول، ستون ها و درج نمونه اطلاعات
ایجاد فولدری با نام php-mysql-signin
تنظیم اطلاعات اتصال به دیتابیس در فایل config.php
فرم HTML جهت ورود و خروج در فایل index.php
بررسی وضعیت ورود کاربر با فایل login.php
برقراری نشست (Session) در پنل کاربری با فایل panel.php
پایان نشست و خروج از سایت با فایل logout.php
دانلود نمونه فایل های آموزش
آموزش ساخت پنل ورود و خروج سایت با PHP و MySQL

در مطلب قبل از بخش آموزش کاربردی PHP و MySQL با نحوه برنامه نویسی سیستم ساده عضویت کاربران در سایت آشنا شدیم، فرم HTML جهت ورود اطلاعات کاربران را نیز با چند فیلد شامل نام کاربری و کلمه عبور جهت نمونه ساختیم و در سمت سرور با کدنویسی PHP داده ها را کنترل و در نهایت در دیتابیس ذخیره کردیم، اکنون در این آموزش می خواهیم کار را با ساخت فرم ورود و خروج تکمیل کنیم تا کاربران پس از ثبت نام در سایت بتوانند به محیط مدیریت وارد شده و از امکانات پنل کاربری شخصی خود استفاده کنند، در این مطلب خواهیم دید که مبحث مربوط به نشست ها (سشن یا Session) برای ایجاد فرم ورود و خروج تا چه میزان اهمیت دارد و با نحوه اعمال تنظیمات سفارشی مربوط به آن بیشتر آشنا خواهیم شد.
سشن (Session) یا نشست چیست و چه کاربردی دارد؟
قبل از اینکه به کدنویسی کار بپردازیم لازم است نگاهی داشته باشیم به اینکه چرا باید در فرآیند ورود و خروج از سشن (Session) یا نشست استفاده کنیم، اصلا این اصطلاح به چه معنی است و چه کاربردی دارد؟
برای درک صحیح مطلب اجازه دهید با یک مثال موضوع را شرح دهیم، فرض کنیم می خواهیم وارد یک نمایشگاه بزرگ کتاب با غرفه های متعدد شویم و برای این کار از قبل در سیستم نمایشگاه اطلاعاتمان را وارد و ثبت نام کرده ایم، در قسمت ورودی نمایشگاه پس از ارائه مدارک شناسایی و در صورت انطباق صحیح نام کاربری و کلمه عبور با اطلاعات موجود در دیتابیس افراد ثبت نام شده، برگه ای با شماره کد اختصاصی و تاریخ انقضاء مشخص به ما تعلق می گیرد که برای ورود به غرفه های گوناگون باید آن را ارائه کنیم (برگه را سشن، کد اختصاصی را همان مقدار سشن و غرفه ها را صفحات یک سایت فرض می کنیم)، در هر ورود به غرفه ها نیز صحت سشن و مدت اعتبار آن بررسی و در صورت تائید با مدت اعتبار جدید به روزرسانی می شود، بر همین روال و با توجه به سیاست های مدیریت ممکن است بعد از خروج از نمایشگاه دیگر نتوانیم با آن برگه وارد شویم (اعتبار برگه منقضی شود) و یا بعد از گذشت چند دقیقه یا چند ساعت اگر وارد هیچ غرفه ای نشده باشیم این اتفاق رخ دهد و مجبور به گرفتن برگه جدید از قسمت ورودی نمایشگاه شویم، حال اگر این برگه که روی آن کد اعتباری ما در مراجعه فعلی به نمایشگاه درج شده است به هر دلیل دریافت نشود یا از بین برود غرفه ها نمی توانند هویت ما را شناسایی کنند و لذا ممکن است اجازه دسترسی به خدماتشان را ندهند.
مشابه همین حالت به نوعی در سایت های وب در مورد بحث نشست یا سشن (Session) اتفاق می افتد، با اجرای هر درخواست ورود و در صورت تائید اطلاعات (معمولا شامل نام کاربری و کلمه عبور) برنامه فایلی با مقدار متنی اختصاصی برای هر کاربر در سرور و همچنین در مرورگر او ایجاد می کند (به فایلی که در سرور ایجاد می شود فایل سشن و به فایلی که در مرورگر ایجاد می شود کوکی گفته می شود) تا در هر بار درخواست صفحات سایت مرورگر مقدار کوکی را ارسال کرده و برنامه با تطبیق اطلاعات ارسالی با مقدار سشن بررسی کند که آیا کاربر مورد نظر دارای اعتبار لازم برای استفاده از صفحه درخواستی می باشد یا خیر، گفتیم این اعتبار در صورتی به کاربر تعلق می گیرد که او نام کاربری و کلمه عبور را به طور صحیح وارد کرده باشد و متغیرهای سشن مربوط به آن نام کاربری در سمت سرور از قبل تنظیم شده و دارای اعتبار باشند (به فرض نشست منقضی نشده یا کاربر از سیستم خارج نشده باشد).
هر نشست در PHP به صورت پیش فرض تا 24 دقیقه اعتبار دارد و اگر در این مدت کاربر هیچ صفحه ای را فراخوانی نکند باید مجددا وارد سایت شود، با فراخوانی هر صفحه مدت اعتبار نشست برای 24 دقیقه دیگر تمدید خواهد شد، این حالت را می توانیم تغییر دهیم که در این خصوص در آموزش بعد مفصل توضیح خواهیم داد.
ساخت دیتابیس، جدول، ستون ها و درج نمونه اطلاعات
کاربران برای ورود به پنل مدیریت ابتدا باید در سایت ثبت نام کرده باشند که در آموزش قبل در این خصوص به صورت اختصاصی صحبت کردیم، لذا در این مطلب جهت جلوگیری از تکرار مباحث گذشته از توضیح دوباره بخش ثبت نام خودداری می کنیم، در صورتی که آموزش قبل را مطالعه نکرده اید لطفا ابتدا با پیروی از مطالب آموزش مندرج در آدرس زیر، دیتابیس، جدول و ستون ها را ساخته و نمونه اطلاعات اولیه را در آن وارد نمائید:
آموزش ساخت فرم عضویت در سایت با PHP و MySQL
پس از ساخت دیتابیس، جدول، ستون ها و درج نمونه اطلاعات اولیه، ساز و کار لازم برای ایجاد مرحله ورود اعضاء به پنل مدیریت فراهم می شود.
ایجاد فولدری با نام php-mysql-signin
برای تجمیع و مدیریت ساده تر فایل های سیستم پنل ورود و خروج سایت بهتر است یک دایرکتوری مجزا در نظر بگیریم، در این آموزش فولدری با نام دلخواه php-mysql-signin ساخته ایم که در مجموع چند فایل و فولدر زیر را شامل می شود:
- فایل config.php، حاوی اطاعات اتصال به دیتابیس.
- فایل index.php، فرم HTML ورود به پنل مدیریت و ترکیب آن با دستورات PHP.
- فایل login.php، بررسی معتبر بودن اطلاعات ارسالی کاربران و انتقال به پنل مدیریت.
- فایل panel.php، پنل مدیریت کاربران سایت.
- فایل logout.php، انقضای کامل نشست و خروج از پنل مدیریت.
- فولدر lib، شامل فایلی با نام password_compat.php جهت استفاده از قابلیت های توابع جدید کلمه عبور در نسخه 5.5 و قدیمی تر PHP.
در ادامه با جزئیات این فایل ها را بررسی می کنیم.
تنظیم اطلاعات اتصال به دیتابیس در فایل config.php
برای اتصال به دیتابیس نیاز به تنظیم چند پارامتر در تابع mysqli_connect است که شامل نام سرور، نام کاربری دیتابیس، کلمه عبور دیتابیس و در نهایت عنوان دیتابیس است، برای تجمیع این موارد و استفاده چندباره از تنظیمات پیکربندی در صفحات مختلف معمولا از فایل Configuration استفاده می شود که در این آموزش نیز بر همین اساس اطلاعات را در فایلی با نام دلخواه config.php به صورت نمونه زیر قرار داده ایم:
<?php
//تنظیمات اتصال به دیتابیس
$config = array(
'host' => 'localhost',
'db_user' => 'نام کاربری دیتابیس',
'db_pass' => 'کلمه عبور دیتابیس',
'db_name' => 'نام دیتابیس'
);
?>
این فایل جهت نمونه است و باید مطابق با اطلاعات دیتابیسمان تکمیل شود.فرم HTML جهت ورود و خروج در فایل index.php
مشابه آنچه در آموزش مربوط به ساخت فرم عضویت در سایت با PHP و MySQL دیدیم برای ورود به پنل مدیریت هم به فرم HTML جهت دریافت نام کاربری و کلمه عبور اعضاء نیازمندیم، البته اگرچه این فرم به صورت HTML است اما بهتر است پسوند فایل را به صورت php ذخیره کنیم چون به دلیل کار با سشن و دریافت اطلاعات از کاربر و به فرض نمایش پیام در حالت ورود و خروج از پنل سایت به کدنویسی PHP نیاز خواهیم داشت، به هر صورت ابتدا فرم زیر را در فایلی با پسوند php و نام دلخواه index.php ایجاد می کنیم:
<?php
if(!isset($check)){
$text = null;
$username = null;
}
?>
<!DOCTYPE html>
<html lang="fa">
<head>
<meta charset="utf-8">
<meta name="viewport" content="width=device-width, initial-scale=1">
<title>وبگو | فرم HTML ورود کاربر به پنل مدیریت سایت</title>
<!-- Webgoo.ir -->
<style>
body{
font-family:Tahoma, Geneva, sans-serif;
direction:rtl;
font-size:12px;
line-height: 22px;
}
.error{
height: 30px;
width: 100%;
color: #dd000a;
}
</style>
</head>
<body>
<?php echo $text; ?>
<form action="login.php" method="post">
<label for="user">نام کاربری:</label>
<input name="username" id="user" type="text" value="<?php echo $username; ?>" maxlength="255" dir="ltr">
<label for="pass">کلمه عبور:</label>
<input name="password" id="pass" type="password" maxlength="255" dir="ltr">
<input name="check" type="hidden" value="1">
<input type="submit" value="ورود به پنل">
</form>
<hr>
- قبل از ورود کاربر به پنل مدیریت سایت ابتدا باید اطلاعات اتصال به دیتابیس را در فایل config.php در آرایه config تعریف کرده باشیم، نام کاربری در لوکال هاست معمولا root و بدون کلمه عبور است.<br>
- اجرای صحیح این کد مستلزم ساخت دیتابیس، جدول، ستون ها و درج نمونه اطلاعاتی است که در آموزش نحوه ساخت فرم عضویت سایت توضیح داده ایم (در صورتی که این آموزش را مطالعه نکرده اید لطفا به بخش آموزش های کاربردی MySQL مراجعه کنید).<br>
- دقت کنیم برای رمزنگاری کلمه عبور در مرحله عضویت کاربر از تابع password_hash استفاده کرده ایم، این تابع از نسخه PHP 5.5 در دسترس است، برای سازگاری نسخه های قدیمی تر کتابخه password_compat به کدها اضافه شده است.<br>
</body>
</html>
توضیح:- دو فیلد اصلی در فرم ورود با نام های username و password مشخص شده اند، فیلد مربوط به کلمه عبور از نوع password است تا کلمه عبور کاربر به شکل حفاظت شده و مخفی وارد شود.
- اطلاعات این فرم به فایلی با نام دلخواه login.php و با متد POST ارسال می شود، با توجه به آدرس دهی قسمت action فرم این فایل باید در کنار فایل index.php قرار داشته باشد.
- فیلد مخفی با نام فرضی check جهت اطمینان از ارسال فرم ورود توسط کاربر است.
- تکه کدهای PHP استفاده شده در این فایل هماهنگ با سایر فایل هایی هستند که در ادامه بررسی خواهیم کرد.
بررسی وضعیت ورود کاربر با فایل login.php
پس از اینکه کاربر اطلاعات خود را در فرم ورود وارد کرده و بر روی دکمه ارسال کلیک می کند، داده ها شامل نام کاربری و کلمه عبور در سرور و کدهای PHP دریافت می شوند، در این مرحله برای اینکه کاربر دسترسی مجاز به پنل کاربری داشته باشد مقادیر ارسالی باید با آنچه که در دیتابیس سرور وجود دارد تطبیق داده شوند، به طور معمول این تطبیق با برنامه نویسی PHP و MySQL انجام می شود که این کار در نمونه کد زیر هماهنگ با فرم عضویتی که در آموزش قبل ساختیم انجام شده است:
<?php
//شروع نشست
session_name('panel');
session_start();
//پیش فرض
$_SESSION['access'] = false;
$_SESSION['user'] = null;
$error = 0;
$text = null;
//فایل تنظیمات اتصال به دیتابیس
include_once('config.php');
//تعریف توابع کلمه عبور در نسخه های پائین تر از PHP 5.5
if(!function_exists('password_hash')) {
include_once('lib/password_compat.php');
}
//دریافت و تعریف متغیرها
@$username = $_POST['username'];
@$password = $_POST['password'];
@$check = $_POST['check'];
/* بررسی معتبر بودن اطلاعات ارسالی کاربر در صورت ارسال فرم */
if($check == 1) {
//نام کاربری
if(!isset($username) || empty($username)) {
$error = 1;
$text = "نام کاربری خود را وارد کنید!";
} //کلمه عبور
elseif(!isset($password) || empty($password)) {
$error = 1;
$text = "کلمه عبور خود را وارد کنید!";
}
//بررسی خطا
if($error === 0) {
//اتصال به دیتابیس
$conn = mysqli_connect($config['host'], $config['db_user'], $config['db_pass'], $config['db_name']);
if(!$conn) {
echo "PHP & MySQL Connection: Error! " . mysqli_connect_errno() . ' - ' . mysqli_connect_error();
exit;
} else {
//ایمن سازی پارامترها
$username = mysqli_real_escape_string($conn, $username);
//نام جدول
$tbl_name = "users";
//اانتخاب اطلاعات از جدول و ستون
$sql = "SELECT `password` FROM $tbl_name WHERE `username` = '$username' LIMIT 1";
$query = mysqli_query($conn, $sql);
if(!$query) {
echo "Selecting From Table $tbl_name: Error! " . mysqli_error($conn) . '<br>';
} else {
//تعداد ردیف های انتخاب شده
$count = mysqli_num_rows($query);
if($count === 0) {
$error = 1;
$text = "نام کاربری یا کلمه عبور اشتباه است!";
} else {
while($row = mysqli_fetch_array($query)) {
$db_hashed_password = $row['password'];
//تطبیق کلمه عبور
if(password_verify($password, $db_hashed_password)) {
$_SESSION['access'] = true;
$_SESSION['user'] = $username;
header("Location: panel.php");
exit;
} else {
$error = 1;
$text = "نام کاربری یا کلمه عبور اشتباه است!";
}
}
}
}
}
//پایان اتصال
mysqli_close($conn);
}
}
//بارگذاری مجدد فرم ورود در صورت بروز خطا یا فراخوانی مجدد
if($check != 1 || $error == 1) {
if($error == 1) {
$text = '<div class="error">' . $text . '</div>';
}
include_once('index.php');
}
?>
دقت کنیم این آموزش هماهنگ با ساختار ایجاد شده در آموزش قبلی است.توضیح:
- اگر بخواهیم نام سشن و کوکی به صورت سفارشی و دلخواه تنظیم شود می توانیم با تابع session_name این کار را انجام دهیم، در غیر اینصورت مفسر PHP به صورت پیش فرض از نام PHPSESSID برای سشن و کوکی استفاده خواهد کرد.
- در گام دوم با تابع session_start یک نشست یا سشن را برای ورود فعلی تعریف می کنیم، دقت کنیم که این تابع باید قبل از ارسال هر نوع خروجی به مرورگر تنظیم شود در غیر اینصورت خطای
Warning: Cannot modify header information - headers already sent...
دریافت خواهیم کرد.- در مرحله بعد متغیرهای پیش فرض برنامه را با مقادیر اولیه تعریف می کنیم.
- با توجه به اینکه توابع مربوط به رمزنگاری و تطبیق کلمه عبور (password_hash و password_verify) در نسخه های قدیمی PHP در دسترس نیستند، از کتابخانه جایگزین password_compat بدین منظور استفاده کرده ایم تا برنامه با این نسخه ها نیز سازگار باشد.
- مقادیر ارسالی کاربر از فرم را در متغیرهایی دریافت می کنیم تا در ادامه کدها از این اطلاعات استفاده کنیم، در اینجا توجه به پارامتر نام (name) فیلدهای input اهمیت زیادی دارد، چرا که متغیرها و مقادیر آنها بر اساس نام فیلد و متد POST مقداردهی می شوند.
- قسمت مربوط به متغیر check برای اطمینان از ارسال فرم توسط کاربر درنظر گرفته شده است، نوع input به صورت hidden یا مخفی است و جلوه ظاهری ندارد اما با ارسال فرم مقدار 1 به سرور ارسال می شود که با این شیوه می توانیم بین دو حالت ارسال و عدم ارسال فرم در کدهای PHP تفاوت قائل شویم.
- برای اعتبارسنجی مقادیر ارسال شده از فرم ورود از دستورات شرطی if و elseif و توابع isset (بررسی وجود یک متغیر) و empty (بررسی خالی نبودن مقدار متغیر) استفاده کرده ایم.
- سپس اتصال به پایگاه داده را با توجه به اطلاعات موجود در فایل config.php برقرار می کنیم، برای سرور مجازی یا لوکال هاست معمولا از نام کاربری root و بدون پسورد استفاده می شود، نام پایگاه داده نیز بستگی به خودمان و دیتابیسی دارد که پیشتر ساخته ایم (در آموزش های مقدماتی MySQL دیدیم که دیتابیس را هم می توانیم با کدهای PHP و هم به صورت دستی در برنامه phpMyAdmin بسازیم).
- بعد از برقراری اتصال به پایگاه داده باید متغیر نام کاربری را با تابع mysqli_real_escape_string ایمن سازی کنیم تا از برنامه در مقابل نفوذ احتمالی به پایگاه داده حفاظت کرده باشیم، البته یادآور می شویم تابع عنوان شده صرفا جهت نمونه و برای کاربردهای متداول است، در صورت لزوم می توانیم از روش های پیشرفته تری مانند Prepared Statement و Bind Param نیز برای افزایش ضریب امنیت استفاده کنیم.
- با دستور SELECT بررسی می کنیم تا ببینیم آیا کاربری با این مشخصات در دیتابیس برنامه وجود دارد یا خیر، اگر تعداد فیلدهای انتخاب شده برابر با 0 باشد (mysqli_num_rows تعداد ردیف های نتایج یک پرس و جو را برمی گرداند)، پس چنین کاربری وجود ندارد و پیغام خطا نمایش داده می شود، در غیر اینصورت اگر مقادیر 1 برگردانده شود این نام کاربری وجود دارد و وارد مرحله تطبیق کلمه عبور می شویم.
- اگر کاربر مشخصات را صحیح وارد کرده و تطبیق با تابع password_verify صحیح (true) باشد دو متغیر از نوع SESSION تنظیم می کنیم، مقادیر access جهت تعیین وضعیت دسترسی مجاز یا غیرمجاز و مقادیر user نام کاربری را در خود نگهداری می کند (در تابع password_verify آرگیومنت اول مقدار خام کلمه عبور دریافتی از فرم ورود و آرگیومنت دوم کلمه عبور رمزی شده ای است که قبلا در مرحله ثبت نام در دیتابیس درج کرده ایم).
- متغیرهای نوع SESSION به صورت سراسری (Superglobal) هستند و بین صفحات مختلف در هر قسمت از برنامه می توانیم به مقدار آنها دسترسی داشته باشیم.
- در صورت تطبیق اطلاعات و پس از تنظیم متغیرهای سشن، کاربر به صورت خودکار به پنل مدیریت هدایت می شود و در صورت عدم تطبیق پیغام خطا نمایش داده خواهد شد.
- در نهایت نیز اتصال به پایگاه داده را با تابع mysqli_close خاتمه می دهیم.
- در صورتی که کاربر فرم را ارسال نکرده یا فرم با خطا مواجه شود، فایل index.php را در انتهای کدهای فایل login.php وارد می کنیم تا فرم ورود نمایش داده شود، این ساز و کار به عنوان نمونه است و جنبه آموزشی دارد، قاعدتا با درک نحوه کار سشن و کوکی می توانیم ساختار سفارشی و مد نظر خودمان را داشته باشیم.
برقراری نشست (Session) در پنل کاربری با فایل panel.php
زمانی که کاربر با موفقیت وارد محیط کاربری برنامه (فایل panel.php) شد برای برقراری پیوسته نشست در هر صفحه از سایتمان که به صورت مستقل فراخوانی می شود باید از توابع session_name و session_start استفاده کنیم، همچنین در صفحاتی که نیاز به دسترسی مجاز به محتوا دارند باید بررسی کنیم و ببینیم که متغیر سشن access تنظیم شده و برابر مقدار true باشد که این کار را با شرط if و تابع isset انجام داده ایم.
فایل محیط کاربری را که در واقع فایل اصلی پنل کاربری برنامه است با نامی انتخابی و صرفا جهت نمونه به صورت panel.php نامگذاری کرده و نمونه کدهای زیر را در آن درج می کنیم:
<?php
//شروع نشست
session_name('panel');
session_start();
//بررسی متغیرهای نشست
if(isset($_SESSION['access']) && $_SESSION['access'] === true) {
echo 'Welcome To Control Panel!<br>User Name: ' . $_SESSION['user'];
echo ' [<a href="logout.php" title="Logout">Logout</a>]';
} else {
header("HTTP/1.1 403 Forbidden");
echo 'HTTP 403 Forbidden – Access Denied!';
exit;
}
?>
این نمونه کد ساختار کلی و اولیه پنل کاربری را نشان می دهد که شامل سه قسمت زیر است:- نام سشن، کوکی و شروع نشست با توابع session_name و session_start، این توابع باید قبل از ارسال هر نوع خروجی به مرورگر اجرا شوند، این خروجی حتی می تواند شامل کاراکترهای نامرئی BOM (مخفف Byte Order Mark) هم باشد که برای اطمینان بهتر است فایل ها با برنامه ++Notepade اجرا و از قسمت Encoding گزینه Encoding in UTF-8 without BOM را انتخاب و مجددا فایل را ذخیره کنیم.
- قسمت مربوط به بررسی وضعیت مجاز بودن دسترسی کاربر که با استفاده از تنظیم متغیر SESSION با نام access و مقدار true (دسترسی مجاز) و یا false (دسترسی غیرمجاز) تعیین می شود، این نوع متغیرها در صورت برقراری نشست در صفحات مختلف در دسترس هستند و می توانیم اطلاعات را از صفحه ای به صفحه دیگر به اشتراک بگذاریم، برای نمونه در اینجا متغیر SESSION با نام usre مقدار نام کاربری را در خود نگهداری می کند و می توانیم با دستور echo از آن خروجی بگیریم.
- در قسمت سوم در صورت عدم برقراری شرط if بخش else اجرا خواهد شد و با تنظیم کد خطای HTTP 403 با استفاده از تابع header دسترسی کاربر به مرورگر غیرمجاز اعلام می شود.
نکته 1: هر نشست در PHP به صورت پیش فرض تا 24 دقیقه اعتبار دارد و اگر کاربر در این فاصله صفحه را رفرش نکرده یا صفحه دیگری را فراخوانی نکند نشست جاری به صورت خودکار منقضی می شود، این تنظیمات از طریق فایل php.ini و همچنین ذخیره و به روزرسانی اطلاعات سشن در دیتابیس قابل تغییر است که در آموزش بعدی در این خصوص بیشتر خواهیم گفت.
نکته 2: این نمونه کد فقط یک ساختار ساده محیط کاربری است و جنبه آموزشی دارد، قاعدتا برنامه های کاربردی نیاز به کدنویسی بیشتر و تعریف امکانات متفاوتی دارند که هر کدام باید در جای خود آموزش داده شوند.
پایان نشست و خروج از سایت با فایل logout.php
اغلب کاربران در مرحله ای از کار نیاز به خاتمه نشست و خروج امن از پنل مدیریت سایت دارند که باید با ساز و کاری این امکان را فراهم کنیم، بدین منظور دو تابع session_unset (حذف متغیرهای نشست) و session_destroy (حذف کامل اطلاعات نشست از سرور) کاربرد دارند که در نمونه کد زیر در فایل logout.php استفاده شده اند:
<?php
//شروع نشست
session_name('panel');
session_start();
//منقضی کردن و حذف اطلاعات نشست
session_unset();
session_destroy();
//انتقال به صفحه ورود
header("Location: login.php");
exit;
?>
توضیح:- از تابع session_unset برای منقضی کردن متغیرهای سشن استفاده می کنیم، متغیرهای نشست در این ساختار شامل access و user هستند که با SESSION و به صورت آرایه تعریف شده اند، در واقع استفاده از این تابع مساوی با حالت زیر است:
$_SESSION = array();
- با تابع session_destroy فایل حاوی اطلاعات نشست از سرور حذف می شود و برای ورود مجدد، نیاز به ارسال نام کاربری و کلمه عبور است.فایل logout.php را هم از طریق لینک و هم با استفاده از فرم HTML و دکمه button یا input می توانیم فراخوانی کنیم:
<a href="logout.php" title="Logout">خروج</a>
<form action="logout.php" method="post">
<input type="submit" value="خروج">
</form>
توضیح:- این فرم صرفا فایل logout.php را فراخوانی می کند و با فراخوانی این فایل سشن به طور کامل منقضی می شود.
- با کمی آشنایی بیشتر با مبحث نشست ها در PHP می توانیم ایده های جالبی تعریف کنیم، به طور مثال پیام خوش آمد گویی و خروج به کاربر نمایش دهیم یا به فرض از مقادیری که در متغیر سشن user وجود دارد برای نمایش نام کاربری استفاده کنیم.
نکته: در نگاه اول مبحث مربوط به سشن ها ممکن است کمی پیچیده به نظر برسد به همین جهت در این مطلب به همین حد اکتفا می کنیم و در آموزش بعدی خواهیم دید که چگونه می توانیم امکانات جانبی بیشتری به فرم ورود و خروج سایت اضافه کنیم.
دانلود نمونه فایل های آموزش
برای جمع بندی کار می توانیم فایل هایی که در این آموزش بررسی کردیم را از لینک زیر دریافت کنیم:
دانلود نمونه فایل های آموزش ساخت پنل ورود و خروج سایت با PHP و MySQL
دسته بندی: آموزش کاربردی » MySQL

ساخت فید آر اس اس (RSS Feed) با استفاده از PHP و MySQL
صفحه بندی مطالب و محتوا با PHP و MySQL
آموزش حذف گروهی اطلاعات از MySQL با استفاده از چک باکس
ایجاد لینک دانلود مدت دار با PHP و MySQL
هوشمند سازی پنل ورود و خروج سایت با PHP و MySQL
دیدگاه


۰۱:۰۶ ۱۴۰۰/۱۱/۰۲
دوست عزیز ممنونم از انتشار این مطلب فقط یه سوال برای این کدی که نوشتید و من هم تستش کردم فقط میخوام که ستون ها بعد از ثبت نام بشه ویرایش کرد میشه کد php رو بدید ممنونم البته من قبلا با کمک شما سایتی رو نوشته بودم که توی کامپیوتر همش حذف شد مجددا باید از نو شروع کنم مشکلمم همین کد ویرایش هست ممنونم
برای ایجاد امکان ویرایش نام کاربری می توانیم یک فایل فرضی به صورت update.php بسازیم، در این فایل فرایند انتخاب اطلاعات از دیتابیس و نمایش در فرم HTML و در نهایت ارسال و به روزرسانی انجام می شود، پس برای مرحله انتخاب اطلاعات می توانیم کدی مشابه زیر داشته باشیم:
در ادامه نام کاربری را در فرم HTML خروجی می دهیم:
<?php
//اتصال به دیتابیس
$conn = mysqli_connect($config['host'], $config['db_user'], $config['db_pass'], $config['db_name']);
if(!$conn) {
echo "PHP & MySQL Connection: Error! " . mysqli_connect_errno() . ' - ' . mysqli_connect_error();
exit;
} else {
echo "PHP & MySQL Connection: Ok!<br>";
//نام جدول
$tbl_name = "users";
//اانتخاب اطلاعات از جدول و ستون
$sql = "SELECT username FROM $tbl_name WHERE `username` = '$_SESSION['user']' LIMIT 1";
$query = mysqli_query($conn, $sql);
if(!$query) {
echo "Selecting From Table $tbl_name: Error! " . mysqli_error($conn) . '<br>';
} else {
//تعداد ردیف های انتخاب شده
$count = mysqli_num_rows($query);
if($count === 0) {
echo "کاربری با این نام در سیستم ثبت نشده است!";
} else {
while($row = mysqli_fetch_array($query)){
$db_username = $row['username'];
}
}
}
}
?>
البته الزاما نیازی به استفاده از SELECT دیتابیس نیست و می توانیم صرفا از متغیر سشن user استفاده کنیم.در ادامه نام کاربری را در فرم HTML خروجی می دهیم:
<form action="update.php" method="post">
<label for="user">نام کاربری:</label>
<input name="username" id="user" type="text" maxlength="255" dir="ltr" value="<?php echo $db_username; ?>">
<input type="submit" value="به روزرسانی">
</form>
پس از ویرایش و ارسال اطلاعات توسط کاربر باید فیلد دیتابیس را آپدیت کنیم://ایمن سازی پارامترها
$username = mysqli_real_escape_string($conn, $username);
//به روزرسانی ردیف
$sql = "UPDATE $tbl_name SET `username` = '$username'";
$query = mysqli_query($conn, $sql);
کد بالا صرفا بخشی از برنامه آپدیت است و قاعدتا نیاز به اتصال به دیتابیس و سایر موارد ضروری مانند مرحله عضویت کاربر در اینجا نیز وجود دارد.m.b
۲۱:۱۴ ۱۴۰۰/۱۰/۱۱
سلام مجدد
تشکر بابت راهنمایی
من یک مشکل دیگه برام بوجود آمد و اون اینکه بعد از ارسال اطلاعت به صفحه questions.php بر میگردد ولی با هر رفرش کردن صفحه آخرین اطلاعات فرم قبلی دوباره وارد دیتابیس میشه. یعنی اگر فرم قبلی پر شده باشه با هر رفرش کردن صفحه مجدد همون اطلاعات با ایدی جدید به دیتابیس ارسال میشه. چکار کنم مشکل حل بشه. ممنون
تشکر بابت راهنمایی
من یک مشکل دیگه برام بوجود آمد و اون اینکه بعد از ارسال اطلاعت به صفحه questions.php بر میگردد ولی با هر رفرش کردن صفحه آخرین اطلاعات فرم قبلی دوباره وارد دیتابیس میشه. یعنی اگر فرم قبلی پر شده باشه با هر رفرش کردن صفحه مجدد همون اطلاعات با ایدی جدید به دیتابیس ارسال میشه. چکار کنم مشکل حل بشه. ممنون
چند راه حل برای رفع این رفتار مرورگر وجود دارد، می توانید برای تگ form یک ID تعریف کنید و ID را در کد زیر به جای form_id جایگزین نمائید:
<script>
var form = document.getElementById("form_id");
function handleForm(event) { event.preventDefault(); }
form.addEventListener('submit', handleForm);
<script>
راه حل دیگر در نظر گرفتن یک فیلد hidden در هر فرم با مقدار ID دیتابیس آن است، به این صورت اگر مجدد فرم با آن ID ارسال شود و ID از قبل در دیتابیس ایجاد شده باشد دیگر اعتبار نداشته باشد، روش دیگر انتقال یا رفرش خود کار صفحه بعد از ارسال فرم است، به فرض:echo "<meta http-equiv='refresh' content='0'>";
m.b
۲۰:۴۷ ۱۴۰۰/۱۰/۱۱
سلام
من یک فرم طراحی کردم جهت ارسال سوال با صفحه questions.php با متد post به صفحه dbquestions.php ارسال میشود. این نمونه کد های صفحه questions.php
من یک فرم طراحی کردم جهت ارسال سوال با صفحه questions.php با متد post به صفحه dbquestions.php ارسال میشود. این نمونه کد های صفحه questions.php
<form action="dbquestions.php" method="post">
<label class="formcontact" style="padding-right:2px;margin-top: 5px;text-align: right;margin-right:3%;font-weight: bolder;color:blue">نام و نام خانوادگی*</label>
<input class="formcontact" name="firstname" type="text"style="height:30px;margin-left:0px;margin-top: 3%;width:95%;border:2px solid #9fcdff;border-radius:5px"required><br>
<label class="formcontact" style="padding-right:0px;margin-top: 5px;margin-right:3%;color:blue">ایمیل*</label>
<input class="formcontact" name="email" type="email" style="height:30px;margin-left:0px;margin-top: 3%;width: 95%;border:2px solid #9fcdff;border-radius:5px"required><br>
<label class="formcontact" style="padding-right:0px;margin-top: 15px;margin-right:3%;margin-top: 3%;color:blue">موضوع*</label>
<input class="formcontact" name="subject"type="text" style="height:30px;margin-left:0px;margin-top: 3%;width:95%;border:2px solid #9fcdff;border-radius:5px"required><br>
<label class="formcontact" style="padding-right:0px;margin-top: 5px;margin-right: 8%;margin-top: 3%;color:blue">شرح*</label>
<textarea class="formcontact" id="id" name="comment" rows="5" cols="10" style="width: 95%;height:110px;margin-top: 5px;border:2px solid #9fcdff;border-radius:5px"required></textarea>
<button type="submit" name="send" style="background:blue;color: white;height:50px;border-radius:10px;margin-top: 5px">ارسال پیام</button>
</form>
سوالات به دیتابیس ارسال میشه. ولی میخوام بعد ارسال اطلاعات مجدد برگرده به صفحه questions.php اینم نمونه کدهای صفحه dbquestions.php<?php
$con=mysqli_connect("localhost","root "," "," ");
// Check connection
if (mysqli_connect_errno()){
echo "به دلیل مشکل زیر، اتصال برقرار نشد : <br />" . mysqli_connect_error();
}
$sql="INSERT INTO questions (name,email,subject,comment,date,time,ip)
VALUES ('$_POST[firstname]','$_POST[email]','$_POST[subject]','$_POST[comment]',now(),now(),'$_SERVER[REMOTE_ADDR]')";
if (!mysqli_query($con,$sql)){
die('خطای زیر رخ داده است : <br />' . mysqli_error($con));
}
echo "<script> alert('اطلاعات با موفقیت ثبت شد')</script>";
header('refresh:0;url=/https://www.site.ir/questions.php');
mysqli_close($con);
?>
راهکارهای متفاوتی برای این حالت می شود در نظر گرفت، یک راه استفاده از include فایل questions.php در انتهای فایل dbquestions.php است، به فرض:
.
.
.
mysqli_close($con);
echo '<br>';
include_once('questions.php');
m.b
۲۰:۳۵ ۱۴۰۰/۱۰/۱۱
با سلام
ضمن تشکر از وب سایت خوبتان
من مطابق کدهای شما عمل کردم و تمامی کدها رو کپی کردم و در دیتابیس هم جدولی به نام users ایجاد کردم و ستون های
ضمن تشکر از وب سایت خوبتان
من مطابق کدهای شما عمل کردم و تمامی کدها رو کپی کردم و در دیتابیس هم جدولی به نام users ایجاد کردم و ستون های
id, username, password
ولی بعد از پر نمودن فیلد های نام کاربری و رمز عبور با وجودی که دقیقا همون اطلاعات در دیتابیس ذخیره شده ولی پیغام میده نام کاربری و رمز عبور اشتباه می باشد این هم نمونه کد های صفحه login.php<?php
//شروع نشست
session_name('panel');
session_start();
//پیش فرض
$_SESSION['access'] = false;
$_SESSION['user'] = null;
$error = 0;
$text = null;
//فایل تنظیمات اتصال به دیتابیس
include_once('config.php');
//تعریف توابع کلمه عبور در نسخه های پائین تر از PHP 5.5
if(!function_exists('password_hash')) {
include_once('lib/password_compat.php');
}
//دریافت و تعریف متغیرها
@$username = $_POST['username'];
@$password = $_POST['password'];
@$check = $_POST['check'];
/* بررسی معتبر بودن اطلاعات ارسالی کاربر در صورت ارسال فرم */
if($check == 1) {
//نام کاربری
if(!isset($username) || empty($username)) {
$error = 1;
$text = "نام کاربری خود را وارد کنید!";
} //کلمه عبور
elseif(!isset($password) || empty($password)) {
$error = 1;
$text = "کلمه عبور خود را وارد کنید!";
}
//بررسی خطا
if($error === 0) {
//اتصال به دیتابیس
$conn = mysqli_connect($config['host'], $config['db_user'], $config['db_pass'], $config['db_name']);
if(!$conn) {
echo "PHP & MySQL Connection: Error! " . mysqli_connect_errno() . ' - ' . mysqli_connect_error();
exit;
} else {
//ایمن سازی پارامترها
$username = mysqli_real_escape_string($conn, $username);
//نام جدول
$tbl_name = "users";
//اانتخاب اطلاعات از جدول و ستون
$sql = "SELECT `password` FROM $tbl_name WHERE `username` = '$username' LIMIT 1";
$query = mysqli_query($conn, $sql);
if(!$query) {
echo "Selecting From Table $tbl_name: Error! " . mysqli_error($conn) . '<br>';
} else {
//تعداد ردیف های انتخاب شده
$count = mysqli_num_rows($query);
if($count === 0) {
$error = 1;
$text = "نام کاربری یا کلمه عبور اشتباه است!";
} else {
while($row = mysqli_fetch_array($query)) {
$db_hashed_password = $row['password'];
//تطبیق کلمه عبور
if(password_verify($password, $db_hashed_password)) {
$_SESSION['access'] = true;
$_SESSION['user'] = $username;
header("Location: panel.php");
exit;
} else {
$error = 1;
$text = "نام کاربری یا کلمه عبور اشتباه است!";
}
}
}
}
}
//پایان اتصال
mysqli_close($conn);
}
}
//بارگذاری مجدد فرم ورود در صورت بروز خطا یا فراخوانی مجدد
if($check != 1 || $error == 1) {
if($error == 1) {
$text = '<div class="error">' . $text . '</div>';
}
include_once('index.php');
}
?>
باید سیستم ثبت نام کاربر را مطابق با آموزش قبل ساخته باشید، به فرض رمزنگاری کلمه عبور در هنگام ثبت نام باید مطابق با آموزش قبل با تابع password_hash انجام شده باشد تا در هنگام تطبیق در مرحله ورود به مشکل عدم همخوانی برنخوریم، برای راهنمایی بیشتر می توانید نسخه ای از سیستم ثبت نام، ورود و نمونه جداول و اطلاعات دیتابیس را به آدرس ایمیل ما (موجود در بخش تماس) ارسال کنید تا بررسی کنیم.
عاطفه
۱۷:۲۱ ۱۴۰۰/۰۶/۰۷
با سلام و خسته نباشید من یک قالب وردپرسی دارم که یک قسمت لاگین (ورود و ثبت نام کاربر) رو داره موقعی که کاربر میخاد ثبت نام کنه سختگیری زیادی برای ایجاد رمز عبور داره امکانش هست منو راهنمایی کنید که با چه کدی میتونم این سخت گیری رو کم کنم یا بردارم؟
اگر سیستم ثبت نام به صورت پلاگین در وردپرس نصب شده است از پنل مدیریت بررسی کنید که امکانی برای تغییر ویژگی های پلاگین در نظر گرفته شده یا خیر؟ اگر چنین امکانی فراهم نبود باید سورس کدهای قسمت ثبت نام ویرایش و تغییر داده شوند که احتمالا زمانبر است و نیاز به دانش برنامه نویسی وب دارد، در هر صورت اگر یک نمونه آدرس از سایت مد نظر درج کنید به درک مشکل بیشتر کمک می کند.
سینا
۱۵:۰۷ ۱۳۹۹/۰۹/۰۷
سلام من وقتی login میکنم مثلا با لپتاپ روی گوشیم هم میبینم login شده چرا اینجوری میشه
احتمالا در برنامه برای هر نام کاربری یک کوکی با مقدار واحد ایجاد و وقتی کوکی در یک دستگاه معتبر می شود در سایر دستگاه ها نیز با فراخوانی صفحات سایت کوکی که از قبل ایجاد شده به سرور فرستاده و اعتبارسنجی می شود، با توجه به انجام لاگین در سایر دستگاه ها کوکی معتبر و مجوز ورود صادر می شود.
محمد
۱۰:۴۹ ۱۳۹۹/۰۷/۰۹
سلام من میخواستم بدونم چه طوری میشه بدون اینکه از کاربر بپرسی که میخواهد از حساب خروج پیدا کند خود سایت بفهمد که کاربر از سایت خروج پیدا کرده
بحث پنل ورود و خروج سایت مبتنی بر مبحث سشن، کوکی و کار با دیتابیس است که برای نمونه در آموزش حاضر توضیح داده شده است، در مورد سوالتان هم این رویه صدق می کند، اگر برنامه مبتنی بر سشن، کوکی و دیتابیس باشد می توانیم با روش های گفته شده در آموزش وضعیت ورود یا خروج را به نحو دلخواه سفارشی سازی کنیم، اگر نیاز به راهنمایی خاصی دارید لطفا سوال را با جزئیات مطرح کنید تا امکان راهنمایی دقیقتر فراهم باشد.
مرتضی پیران
۰۰:۰۳ ۱۳۹۹/۰۱/۲۵
سلام خسته نباشید من یه مشکلی داشتم من یه صفحه ثبت نام طراحی کردم چطوری میتونم وقتی کاربر تو سایت ثبت نام کرد اطلاعات خودش رو تو صفحه پنل کاربریش ببینه و ویرایش کنه خیلی گشتم نتونستم چیزی پیدا کنم اگه کمکم کنید ممنون میشم
ویرایش اطلاعات مرحله بعد از ثبت نام و ذخیره سازی است، در اینجا باید با اجرای پرس و جوی SELECT اطلاعات موجود از دیتابیس استخراج و با PHP به عنوان value در تگ های زیرمجموعه form در HTML مانند تگ input خروجی داده شود، سپس در نهایت فرم ارسال شده و مجدد با دستور UPDATE در MySQL اطلاعات جدید جایگزین موارد قبلی دیتابیس می شود، نمونه کد:
https://www.sourcecodester.com/php/11546/easy-and-simple-add-edit-delete-mysql-table-rows-using-phpmysqli.html
هومن
۱۴:۲۰ ۱۳۹۸/۰۳/۱۳
سلام میشه بگین این پوشه html رو چگونه به php ارتباط بدیم
سوالتان مبهم است! در مطلب از پوشه صحبتی نشده؟! برای استفاده از آموزش های کاربردی باید سطحی از آموزش های مقدماتی را گذرانده باشید در این صورت توضیحات لازم در آموزش ذکر شده است.
amin
۲۳:۲۸ ۱۳۹۸/۰۲/۱۱
با سلام و خسته نباشید من با استفاده از آموزش شما یه فرم لاگین رو ساختم و ابتدا خیلی خوب کار می کرد ولی الان سشن ها نه روی هاست و نه روی لوکال اصلا کار نمی کنند
هرچند بدون بررسی سورس کدها و تست برنامه نمی توان نظر قطعی داد اما اینگونه مشکلات می تواند به فرض ناشی از وجود کاراکترهای نامرئی به نام BOM یا Byte Order Mark در فایل باشد، توضیح اینکه برخی ویرایشگرها و برنامه ها در هنگام ذخیره کردن فایل کاراکترهایی به صورت نامرئی به ابتدای آن اضافه می کنند که این به جهت مشخص شدن یونیکد فایل است، اما این کار باعث بروز مشکل با توابع headers (مانند توابع سشن) می شود چون قبل از اینگونه توابع نباید هیچ خروجی ارسال شود، راه حل آن استفاده از برنامه هایی مانند ++Notepad یا Adobe Dreamweaver است، در این برنامه ها در هنگام ذخیره یا در قسمت Encoding می توانیم BOM را حذف کنیم، در صورتی که مشکل از این موارد نباشد نیاز به بررسی دارد (می توانید فایل ها را به آدرس ایمیل ما موجود در بخش تماس ارسال کنید).
Ali.joker
۱۴:۰۴ ۱۳۹۸/۰۲/۰۸
سلام خسته نباشید
من میخاستم یه فرم لاگین درست کنم که وقتی کاربر اطلاعاتشو درست وارد میکنه داخل بشه ولی وقتی اشتباه وارد میکنه داخل همون صفحه لاگین بزنه اطلاعات اشتباست و به صفحه ی دیگه ای نره
لطفا راهنمایی کنید
ممنون
من میخاستم یه فرم لاگین درست کنم که وقتی کاربر اطلاعاتشو درست وارد میکنه داخل بشه ولی وقتی اشتباه وارد میکنه داخل همون صفحه لاگین بزنه اطلاعات اشتباست و به صفحه ی دیگه ای نره
لطفا راهنمایی کنید
ممنون
اصول کار در آموزش حاضر توضیح داده شده، برای سفارشی سازی نحوه ورود و خروج باید با برنامه نویسی وب آشنایی داشته باشید، در این صورت به راحتی می توانید کدهای HTML را با PHP در یک فایل واحد ترکیب کنید، قاعدتا قسمت هایی مانند action فرم نیز باید ویرایش شوند.
آرش
۰۹:۰۷ ۱۳۹۷/۱۲/۱۶
سلام ببخشید من یک مشکل دارم تازه سایت سازی رو یاد گرفتم میشه مشکلم اینه که بعضی سایتا میبینید چند تا موضوع دارن هرکدوم سرچ میکنی تو گوگل میاد مثلا وارد سایت میشی اینطوری میشه
فقط همین میاد
webgoo.ir/photo
مثلا دانلود عکس هست ولی من نمیتونم تو سایتم چند تا لینک بزارم فقط همین میاد
webgoo.ir
چطور چند تا لینک تو سایتم بزارملینک ها آدرس ارجاع به صفحات وب هستند و می توانید به هر تعداد که بخواهید با تگ a لینک ایجاد کنید، منتها مراحل انجام کار بستگی به سیستم مدیریت محتوا (CMS) دارد که از آن استفاده می کنید، قاعدتا ابتدا باید یک صفحه وب (داینامیک یا استاتیک) ایجاد کنید و سپس به آدرس آن لینک دهید، توصیه می کنیم در خصوص HTML آموزش ها را از سطح مقدماتی مطالعه کنید و با نحوه کار و امکانات CMS مورد نظر خود (به فرض وردپرس، جوملا و...) نیز آشنا شوید.
۲۱:۱۱ ۱۳۹۷/۰۹/۰۱
در گوگل فرم آزمون طراحی کردم برای دانش آموزان میخوام این فرم نام کاربری یا رمز ورود داشته باشه مثل کد ملی که قبلا این ها را تهیه کنم با وارد کردن کد ملی مشخصات فرد مشخص شود با کد خود وارد شود تا کسی نتوانه به جای کس دیگه وارد شده و امتحان بده
برای این موارد بهتر است زبان برنامه نویسی سمت سرور مانند PHP بلد باشید، گوگل فرم امکاناتی در چارچوب مشخص و محدود ارائه می کند.
نوید
۱۱:۵۹ ۱۳۹۷/۰۶/۰۵
سلام و وقت بخیر.
2 تا سوال دارم:
1- من یک جدول در دیتابیس دارم به اسم product و میخوام هر شخصی که لاگین میکنه و کالایی رو ثبت میکنه، اون کالا به اسم همون شخص ثبت بشه.
2- زمانی که این کالاها نمایش داده میشن روی سایت، نام مالک اون هم نمایش داده میشه و اگه کس دیگه ای که لاگین کرده درخواست استفاده از این کالا رو بده، تو صفحه شخصی مالک، پیغامی ظاهر بشه.
پیشاپیش ممنون از راهنمایی تون
2 تا سوال دارم:
1- من یک جدول در دیتابیس دارم به اسم product و میخوام هر شخصی که لاگین میکنه و کالایی رو ثبت میکنه، اون کالا به اسم همون شخص ثبت بشه.
2- زمانی که این کالاها نمایش داده میشن روی سایت، نام مالک اون هم نمایش داده میشه و اگه کس دیگه ای که لاگین کرده درخواست استفاده از این کالا رو بده، تو صفحه شخصی مالک، پیغامی ظاهر بشه.
پیشاپیش ممنون از راهنمایی تون
سوالتان کلی است و توضیح کوتاهی ندارد، قاعدتا باید متناسب با هدفی که دارید ساختار دیتابیس خود را تعریف و بر همان اساس کدهای مورد نیاز را با برنامه نویسی PHP بنویسید، به طور مثال نام کاربر می تواند از جدول کاربران دریافت و در یک سشن آی دی نگهداری شود و در هنگام ثبت کالا در پرس و جوی INSERT استفاده گردد، به همین طریق در زمان نمایش و SELECT اطلاعات نام مالک از ستون مربوطه دریافت و نمایش داده شود، در واقع باید برنامه نویسی PHP و MySQL را از مقدمات فرا گرفته باشید.
احسان
۰۱:۲۷ ۱۳۹۷/۰۳/۲۹
سلام. من با ادوب میوز سایت میسازم. همیشه وقتی یه سری کد رو تو این نرم افزار کپی پیست میکنم خود نرم افزار کد رو میخونه و همه چیز رو برام به نمایش در میاره ولی کدهای شما رو این نرم افزار نمیتونه برام به نمایش بزاره و اصلا این کدها رو به عنوان کد نمیشناسه. من چیکار کنم تا میوز بتونه کدها رو بخونه؟
مثلا کد لازم برای بوجود آمدن چت روم در گوشه پایین صفحه رو قشنگ خوندش. این کد رو مثلا
مثلا کد لازم برای بوجود آمدن چت روم در گوشه پایین صفحه رو قشنگ خوندش. این کد رو مثلا
حذف شد
ولی کدهای شما رو نمیخونه... امیدوارم به ادوب میوز آشناییت داشته باشد.با توجه به توضیحات ظاهرا نرم افزار اشاره شده صرفا قادر به پردازش کدها و اسکریپت های سمت کاربر مانند HTML و JavaScript است، در صورتی که برای اجرای کدهای PHP نیازمند سرور مجازی یا سرور آنلاین هستید، لطفا توجه داشته باشید مواردی مانند پنل ورود و خروج سایت را نمی توانید به صورت آماده و از قبل طراحی شده داشته باشید و باید با برنامه نویسی آشنا بوده و کدها را در سرور اجرا نمائید.
- به سوالات کلی، زمانبر، مبهم و مشکلاتی که تلاشی برای رفع آنها نکرده باشید پاسخ مختصر داده شده یا به بخش برنامه نویسی اختصاصی ارجاع داده می شوند.
- کدها و اسکریپت های طولانی را ترجیحا در یک صفحه وب آنلاین یا به صورت حساب موقت و آزمایشی قرار دهید تا امکان بررسی دقیق مشکل و خطایابی میسر باشد.
- تمام دیدگاه های ارسالی خوانده شده و برای هر کاربر مدت زمان لازم جهت پاسخگویی در نظر گرفته می شود، لطفا از طرح سوالات متعدد در بازه زمانی کوتاه خودداری کنید.