نمایش آمار بازدیدها با PHP بدون استفاده از دیتابیس

از جمله امکانات اولیه ای که ممکن است برای خیلی از سایت ها کاربردی باشد، نمایش آمار بازدیدها به مخاطبان است که وبمسترها برای رسیدن به این هدف از روش های مختلفی بهره می برند، به طور مثال برخی ترجیح می دهند از ابزارهای رایگان در سرویس های مختلف استفاده کنند، برخی از سایت های مرجع و عده ای نیز به دنبال راه اندازی سیستم شخصی خود هستند، به هر صورت در این مطلب برای کسانی که می خواهند سیستم نمایش آماری مستقل، بدون صرف منابع سرور، بدون استفاده از دیتابیس و بدون سر و کار داشتن با دانش برنامه نویسی سطح بالا داشته باشند و آمار بازدیدهای سایت خود را به صورت مختصر و مفید برای مخاطبان نمایش دهند، آموزش تقریبا کاملی در نظر گرفته ایم که امیدواریم مفید واقع شود، در این آموزش خواهیم دید که چگونه می توان با چند خط کدنویسی PHP یک سیستم ساده اما هوشمند و کاربردی محاسبه و نمایش آمار بازدیدها را ساخت.
چرا از آمارگیر بدون استفاده از دیتابیس استفاده کنیم؟
سوالی که ممکن است در نگاه اول به ذهن برسد این است که با وجود سیستم های آمارگیر موجود، چه لزومی دارد که از سیستم آمارگیر بدون دیتابیس استفاده کنیم؟
البته پاسخ این سوال روشن است، در حالت کلی لزومی وجود ندارد!، معمولا به فراخور انتظاراتی که ما از یک سیستم نمایش آمار بازدیدها داریم، می توانیم از برنامه ای خاص و پیچیده یا از کدی سبک و شخصی استفاده کنیم، به طور مثال برخی به فراخور نیاز، سلیقه یا نوع فعالیتشان در وب تمایل دارند که صرفا آمار بازدیدها را برای کاربران نمایش دهند و برایشان اهمیتی ندارد که اطلاعات و تجزیه تحلیل های اضافه را نیز در اختیار داشته باشند، از طرفی ابزارهای رایگان و سیستم های وابسته به سایر سایت ها اگرچه ممکن است مزایایی داشته باشند اما باید توجه نمود که اغلب اوقات موجب بروز مشکلاتی مانند از دسترس خارج شدن سرویس، کند شدن سرعت بارگذاری صفحات، وجود لینک های بعضا غیر استاندارد به سایت سرویس دهنده و... می شوند، از طرفی سیستم های شخصی مبتنی بر دیتابیس نیز در عین مزایایی که دارند با محدودیت هایی مواجه هستند، از جمله اینکه الزاما باید دیتابیسی در اختیار داشته باشیم، میزان فضای کافی برای ذخیره اطلاعات موجود باشد، برنامه مدیریت بازدیدها را بنویسیم و لذا به سطح بالایی از دانش برنامه نویسی نیازمندیم و مواردی از این دست، لذا ملاحظه می کنید که هر روشی ممکن است مزایا و در عین حال معایب خاص خود را داشته باشد و این ما و هدفمان است که تعیین می کند از چه شیوه ای استفاده کنیم.
کد PHP برای محاسبه و نمایش آمار بازدیدها، نسخه ساده
برای محاسبه و نمایش آمار بازدیدها می توانیم از کد PHP زیر که در دو نسخه ساده و پیشرفته نوشته شده است استفاده کنیم، نسخه ساده این کد قادر به محاسبه و نمایش آمار بازدیدهای امروز، دیروز، بازدید کل و نمایش افراد آنلاین است، برای قسمت افراد آنلاین از IP کاربران جهت تفکیک آنها استفاده شده و به صورت پیش فرض بعد از هر بار بارگذاری صفحات سایت، آن کاربر تا 5 دقیقه آنلاین محسوب می شود و با رفرش یا بارگذاری صفحات دیگر، این زمان به صورت هوشمندانه به روز شده و از نو محاسبه می گردد، از جمله سایر امکانات این ابزار به ظاهر کوچک، قابلیت حذف خودکار IP کاربرانی است که دیگر آنلاین نیستند، این کار از اضافه شدن بی مورد حجم فایل برنامه جلوگیری می کند.
<?php
//آمار بازدیدهای امروز، دیروز، کل و نمایش افراد آنلاین
?>
<!DOCTYPE html>
<html lang="fa">
<head>
<meta charset="utf-8">
<meta name="viewport" content="width=device-width, initial-scale=1">
<title>وبگو | نمایش آمار بازدیدها بدون دیتابیس</title>
<!-- Webgoo.ir -->
<style>
body {
font-family: Tahoma, Geneva, sans-serif;
font-size: 12px;
direction: rtl;
}
.stats {
display: block;
margin-left: auto;
margin-right: auto;
width: 150px;
height: auto;
border: 1px solid #CCC;
padding: 4px;
line-height: 20px;
}
</style>
</head>
<body>
<?php
//اختلاف زمانی سرور
$time_zone = 12600;
//تاریخ امروز
$today = date("Y-m-d", time() + $time_zone);
//تاریخ دیروز
$yesterday = date("Y-m-d", time() - 86400 + $time_zone);
//آدرس فایل
$file_src = 'visit-stats.txt';
chmod($file_src, 0755);
//خواندن فایل
$read_file = file_get_contents($file_src);
//اگر فایل خالی نبود
if (filesize($file_src) > 0 || $read_file != ''){
$split_file = explode('|', $read_file);
//print_r($split_file);
$modify = $split_file[3];
//اگر تاریخ آخرین ویرایش برابر تاریخ امروز نبود
if($modify != $today){
$today_visit = 1;
if($modify == $yesterday){
$yesterday_visit = $split_file[0];
} else{
$yesterday_visit = 0;
}
$total_visit = $split_file[2] + 1;
$last_modify = $today;
} //اگر تاریخ آخرین ویرایش برابر امروز بود
else{
$today_visit = $split_file[0] + 1;
$yesterday_visit = $split_file[1];
$total_visit = $split_file[2] + 1;
$last_modify = $today;
}
} //اگر فایل خالی بود
else{
$today_visit = 1;
$yesterday_visit = 0;
$total_visit = 1;
$last_modify = $today;
}
//نوشتن آمار جدید در فایل
$file_src_handle = fopen($file_src, 'w+');
$visit_data = $today_visit . '|' . $yesterday_visit . '|' . $total_visit . '|' . $last_modify;
fwrite($file_src_handle, $visit_data);
fclose($file_src_handle);
//محاسبه تعداد کاربران آنلاین
$config_array = array(
'user_time' => date("YmdHis", time() + $time_zone),
'user_ip' => $_SERVER['REMOTE_ADDR'],
'file_name' => 'visit-online.txt'
);
chmod($config_array['file_name'], 0755);
//خواندن اطلاعات فایل
$online_file = file_get_contents($config_array['file_name']);
//تجزیه به آرایه
$online_file = explode("\r\n", $online_file);
//حذف مقادیر خالی
foreach($online_file as $key=> $value){
if(is_null($value) || $value == ''){
unset($online_file[$key]);
}
}
//حذف آی پی های قدیمی و آی پی فعلی
foreach($online_file as $key=> $value){
$user_ip_time = explode("|", $value);
if($user_ip_time[1] <= date("YmdHis", time() + $time_zone - 300)){
unset($online_file[$key]);
}
if($user_ip_time[0] == $config_array['user_ip']){
unset($online_file[$key]);
}
}
//محاسبه تعداد افراد آنلاین
$online = 1;
foreach($online_file as $online_users){
$user_ip_time = explode("|", $online_users);
if($user_ip_time[1] >= date("YmdHis", time() + $time_zone - 300)){
$online++;
}
}
//آمار کاربرانی که آنلاین هستند به اضافه کاربر فعلی
$new_online = $config_array['user_ip'] . "|" . $config_array['user_time'] . "\r\n";
foreach($online_file as $key=> $value){
$new_online .= $value . "\r\n";
}
//نوشتن آمار جدید در فایل
$file_src_handle = fopen($config_array['file_name'], 'w+');
fwrite($file_src_handle, $new_online);
fclose($file_src_handle);
//////////////// Webgoo.ir ///////////////
//گرفتن خروجی
echo '<div class="stats">
» بازدید امروز: ' . $today_visit . '<br>
» بازدید دیروز: ' . $yesterday_visit . '<br>
» بازدید کل: ' . $total_visit . '<br>
» افراد آنلاین: ' . $online . '
</div>';
?>
</body>
</html>
برای استفاده از این برنامه قبل از هر چیز کدها را در یک فایل PHP با نام دلخواه (به طور مثال stats.php) ذخیره کرده و دو فایل با فرمت txt با نام های visit-stats.txt و visit-online.txt در کنار فایل اصلی برنامه ایجاد می کنیم، از این دو فایل برای ذخیره و نمایش اطلاعات مربوط به بازدیدها و افراد آنلاین استفاده خواهیم کرد، سپس در ابتدای کد، اختلاف زمان محلی و زمان سرور خود را مشخص می کنیم، به طور مثال اگر زمان سرور بر روی GMT تنظیم شده باشد، اختلاف محلی برای ایران در حالت معمول معادل 3:30 ساعت و به عبارتی 12600 ثانیه است (60*60 برابر 3600 ثانیه برای یک ساعت).توضیح:
- با تابع date و time تاریخ امروز را به صورت میلادی به دست می آوریم، سپس از همین روش استفاده کرده و زمان فعلی را از 86400 ثانیه که معادل 24 ساعت است (3600 * 24) کم می کنیم تا تاریخ دیروز نیز مشخص شود.
- در گام بعدی فایل مورد نظر جهت ذخیره و بازیابی آمار بازدیدها را تعیین کرده و با تابع file_get_contents اطلاعات آن را می خوانیم، همچنین برای اطمینان از قابل ویرایش بودن فایل، با تابع chmod مجوزهای ویرایش (Permission) را بر روی عدد 0755 تنظیم می کنیم.
- اگر حجم فایل بیشتر از 0 بایت بود یا اینکه فایل خالی نبود یعنی قبلا آماری در آن ثبت شده است، در این صورت آمار باید به صورت نمونه زیر ثبت شده باشد:
24|92|124|2012-10-26
در اینجا عدد اول تعداد بازدیدهای امروز، عدد دوم بازدیدهای دیروز، عدد سوم بازدید کل و عبارت آخر تاریخ آخرین ویرایش فایل مزبور است، همان طور که ملاحظه می کنید از یک جدا کننده با علامت (|) استفاده کرده ایم، این جداکننده زمانی که با تابع explode کار می کنیم لازم است و می توان با آن بخش های مختلف را از هم تفکیک و تجزیه کرد و نتیجه را به صورت یک آرایه تبدیل نمود.- زمانی که اطلاعات به آرایه تبدیل می شوند می توان به مقادیر کلیدهای آن دسترسی داشت، به طور مثال در کد بالا اگر با print_r از متغیر split_file خروجی بگیریم، نتیجه به شکل نمونه زیر خواهد بود.
Array
(
[0] => 345
[1] => 431
[2] => 17345
[3] => 2012-10-26
)
ملاحظه می کنید که شمارش کلیدها از صفر شروع شده و تا 3 ادامه پیدا می کند، به طور مثال کلید 3 تاریخ آخرین ویرایش فایل را در خود دارد (برای کسب اطلاعات بیشتر در این خصوص لطفا به بخش آرایه ها در آموزش های مقدماتی PHP مراجعه کنید).- در گام بعدی بررسی می کنیم تا ببینیم آیا تاریخ آخرین ویرایش فایل برابر تاریخ امروز است یا خیر، اگر این طور باشد بازدید امروز و بازدید کل باید افزایش یابند، اما اگر تاریخ امروز با تاریخ آخرین ویرایش تفاوت کند محاسبه بازدیدها وارد یک روز جدید شده و آمار فعلی باید به عنوان آمار دیروز در نظر گرفته شود و بازدید امروز نیز از نو شروع شده و نهایتا بازدید کل نیز افزایش یابد (درک صحیح عملکرد اسکریپت با کمی تامل و آشنایی با مبحث آرایه ها آسان می گردد).
- اما اگر حجم فایل بیش از 0 بایت نبود یا اینکه فایل خالی باشد اولین باری است که اطلاعات در آن ذخیره می شود، لذا آمار امروز برابر 1، آمار دیروز برابر 0 و آمار کل برابر با 1 خواهد بود.
- در نهایت نیز با توابع fopen و متد +w و همچنین تابع fwrite و fclose فایل را بازکرده و اطلاعات جدید را در آن می نویسیم، در اینجا اگر در برخی سرورها با وجود استفاده از تابع chmod با خطای سطح دسترسی پائین برای ویرایش فایل مواجه شدیم، باید به کنترل پنل هاست خود رفته و به صورت دستی مجوزهای ویرایش (Permission) را بر روی عدد 755 تنظیم کنیم.
- در قسمت دوم اسکریپت تعداد افراد آنلاین را محاسبه می کنیم، برای این کار ابتدا در آرایه config_array زمان فعلی، IP کاربر و آدرس فایل را مشخص می کنیم (مقادیر آرایه به صورت کلیدهای 0 تا 2 در دسترس هستند).
- در اینجا از دو علامت جدا کننده استفاده می کنیم، علامت (\r\n) که برای ایجاد یک خط جدید و آرایش ردیفی اطلاعات هر کاربر کاربرد دارد و علامت (|) که بین IP و زمان آن تفکیک ایجاد می کند، به فرض:
127.0.0.1|20121026134434
127.0.0.2|20121026134324
127.0.0.3|20121026134233
نکته: علامت (\r\n) قابل روئیت نیست اما باعث ایجاد خط جدید می شود و در فایل وجود دارد.- ابتدا در یک حلقه foreach کلیدهایی که مقادیر خالی دارند را از آرایه حذف می کنیم (با استفاده از unset)، در واقع این کار برای جلوگیری از محاسبه آخرین خط در تعداد افراد آنلاین است (آخرین خط صرفا علامت (\r\n) را در خود دارد و لذا مقادیر آن خالی است، برای دیدن جزئیات فایل visit-online.txt را با یک ویرایشگر (مانند ++Notepad) که شماره خطوط را نشان دهد باز کنید، خواهید دید که خط آخر مقادیری ندارد).
- در حلقه foreach بعدی IP و زمان کاربرانی که از حالت آنلاین خارج شده اند (یعنی بیش از حداکثر زمان تعیین شده غیرفعال بوده اند) را حذف می کنیم، علاوه بر این اطلاعات قبلی کاربر فعلی را نیز از لیست آرایه حذف می کنیم.
- اکنون تعداد IP های باقی مانده را محاسبه کرده و به همراه کاربر فعلی در متغیر online مقداردهی می کنیم.
- سپس آمار کاربرانی که آنلاین هستند و کاربر فعلی را به طور مجدد در فایل visit-online.txt ذخیره می کنیم، این کار برای جلوگیری از افزایش بیش از حد حجم فایل مفید است (اگر این کار را نکنیم اطلاعات قدیمی بی جهت در فایل ما ذخیره شده و حجم فایل به مرور و به طور مداوم افزایش می یابد).
- در نهایت نیز متغیرهای اصلی برنامه را به خروجی می دهیم، برای این کار از دستور echo استفاده کرده ایم.
کد PHP برای نمایش آمار بازدیدهای هفته و ماه، نسخه پیشرفته
برای کاربرانی که تمایل دارند علاوه بر آمار بازدید امروز، دیروز و کل، بازدیدهای هفته (7 روز گذشته) و ماه (30 روز گذشته) را نیز به مخاطبان خود نمایش دهند، کد بالا را به نحوی توسعه داده ایم که به جای 2 روز، اطلاعات بازدیدهای 30 روز گذشته را در خود نگهداری کند، یادآور می شویم که این کد لزوما مطابق با روزهای هفته یا ماه در تقویم شمسی یا میلادی نیست و صرفا قادر به نگهداری و تجزیه تحلیل بازدیدهای 7 و 30 روز گذشته صرف نظر از تطابق با روزهای هفته و ماه در تقویم است، نوشتن آمارگیر مطابق با روزهای تقویم نیازمند وجود دیتابیس و ثبت دقیق جزئیات بازدیدها است که این برنامه برای این کار ساخته نشده است.
<?php
//آمار بازدیدهای امروز، دیروز، 7 روز گذشته، 30 روز گذشته، کل و نمایش افراد آنلاین
?>
<!DOCTYPE html>
<html lang="fa">
<head>
<meta charset="utf-8">
<meta name="viewport" content="width=device-width, initial-scale=1">
<title>وبگو | نمایش آمار بازدیدها بدون دیتابیس</title>
<!-- Webgoo.ir -->
<style>
body {
font-family: Tahoma, Geneva, sans-serif;
font-size: 12px;
direction: rtl;
}
.stats {
display: block;
margin-left: auto;
margin-right: auto;
width: 150px;
height: auto;
border: 1px solid #CCC;
padding: 4px;
line-height: 20px;
}
</style>
</head>
<body>
<?php
//اختلاف زمانی سرور
$time_zone = 12600;
//تاریخ امروز
$today = date("Y-m-d", time() + $time_zone);
//تاریخ دیروز
$yesterday = date("Y-m-d", time() - 86400 + $time_zone);
//متغیرهای پیش فرض
$week_visit = 0;
$month_visit = 0;
$month_str = null;
//آدرس فایل
$file_src = 'visit-stats.txt';
chmod($file_src, 0755);
//خواندن فایل
$read_file = file_get_contents($file_src);
//اگر فایل خالی نبود
if (filesize($file_src) > 0 || $read_file != ''){
$split_file = explode('|', $read_file);
//print_r($split_file);
$modify = $split_file[31];
//اگر تاریخ آخرین ویرایش برابر تاریخ امروز نبود
if($modify != $today){
$today_visit = 1;
if($modify == $yesterday){
$yesterday_visit = $split_file[0];
} else{
$yesterday_visit = 0;
}
$week_visit += $today_visit + $yesterday_visit;
$month_visit += $today_visit + $yesterday_visit;
for($i = 2; $i < 30; $i++) {
$month_str .= $split_file[$i - 1];
if($i < 29) {
$month_str .= '|';
}
if($i < 8) {
$week_visit += $split_file[$i - 1];
}
$month_visit += $split_file[$i - 1];
}
$total_visit = $split_file[30] + 1;
$last_modify = $today;
} //اگر تاریخ آخرین ویرایش برابر امروز بود
else{
$today_visit = $split_file[0] + 1;
$yesterday_visit = $split_file[1];
$week_visit += $today_visit + $yesterday_visit;
$month_visit += $today_visit + $yesterday_visit;
for($i = 2; $i < 30; $i++) {
$month_str .= $split_file[$i];
if($i < 29) {
$month_str .= '|';
}
if($i < 8) {
$week_visit += $split_file[$i];
}
$month_visit += $split_file[$i];
}
$total_visit = $split_file[30] + 1;
$last_modify = $today;
}
} //اگر فایل خالی بود
else{
$today_visit = 1;
$yesterday_visit = 0;
$week_visit = 1;
$month_visit = 1;
for($i = 2; $i < 30; $i++) {
$month_str .= '0';
if($i < 29) {
$month_str .= '|';
}
}
$total_visit = 1;
$last_modify = $today;
}
//نوشتن آمار جدید در فایل
$file_src_handle = fopen($file_src, 'w+');
$visit_data = $today_visit . '|' . $yesterday_visit . '|' . $month_str . '|' . $total_visit . '|' . $last_modify;
fwrite($file_src_handle, $visit_data);
fclose($file_src_handle);
//محاسبه تعداد کاربران آنلاین
$config_array = array(
'user_time' => date("YmdHis", time() + $time_zone),
'user_ip' => $_SERVER['REMOTE_ADDR'],
'file_name' => 'visit-online.txt'
);
chmod($config_array['file_name'], 0755);
//خواندن اطلاعات فایل
$online_file = file_get_contents($config_array['file_name']);
//تجزیه به آرایه
$online_file = explode("\r\n", $online_file);
//حذف مقادیر خالی
foreach($online_file as $key=> $value){
if(is_null($value) || $value == ''){
unset($online_file[$key]);
}
}
//حذف آی پی های قدیمی و آی پی فعلی
foreach($online_file as $key=> $value){
$user_ip_time = explode("|", $value);
if($user_ip_time[1] <= date("YmdHis", time() + $time_zone - 300)){
unset($online_file[$key]);
}
if($user_ip_time[0] == $config_array['user_ip']){
unset($online_file[$key]);
}
}
//محاسبه تعداد افراد آنلاین
$online = 1;
foreach($online_file as $online_users){
$user_ip_time = explode("|", $online_users);
if($user_ip_time[1] >= date("YmdHis", time() + $time_zone - 300)){
$online++;
}
}
//آمار کاربرانی که آنلاین هستند به اضافه کاربر فعلی
$new_online = $config_array['user_ip'] . "|" . $config_array['user_time'] . "\r\n";
foreach($online_file as $key=> $value){
$new_online .= $value . "\r\n";
}
//نوشتن آمار جدید در فایل
$file_src_handle = fopen($config_array['file_name'], 'w+');
fwrite($file_src_handle, $new_online);
fclose($file_src_handle);
//////////////// Webgoo.ir ///////////////
//گرفتن خروجی
echo '<div class="stats">
» بازدید امروز: ' . $today_visit . '<br>
» بازدید دیروز: ' . $yesterday_visit . '<br>
» بازدید هفته: ' . $week_visit . '<br>
» بازدید ماه: ' . $month_visit . '<br>
» بازدید کل: ' . $total_visit . '<br>
» افراد آنلاین: ' . $online . '
</div>';
?>
</body>
</html>
دستور العمل نحوه استفاده از این کد نیز مشابه با حالت ساده آن است که در ابتدای مطلب آموزش داده شد، کافی است کدها را در یک فایل PHP با نام دلخواه (به طور مثال stats.php) ذخیره کرده و در کنار فایل PHP دو فایل با فرمت txt با نام های visit-stats.txt و visit-online.txt ایجاد کنیم.نکته 1: در صورتی که فایل visit-stats.txt از قبل و برای نسخه ساده برنامه وجود دارد، برای نصب، راه اندازی مجدد و استفاده از نسخه پیشرفته برنامه، محتوای این فایل باید خالی باشد!
نکته 2: یادآور می شویم این برنامه لزوما مطابق با روزهای هفته و ماه در تقویم هجری شمسی یا میلادی نیست و صرفا آمار بازدیدهای 7 و 30 روز گذشته را نگهداری می کند، نوشتن سیستم آمارگیر مطابق با تقویم نیازمند وجود دیتابیس اطلاعاتی و در اختیار داشتن جزئیات دقیق بازدیدها است.

ارسال پارامتر به URL و دریافت مقادیر با PHP
ساخت فید خوان آر اس اس (RSS Feed Reader) با PHP
محدود کردن لینک دانلود مستقیم فایل ها با PHP و htaccess
نحوه نمایش متن و تصاویر اتفاقی در PHP و MySQL
تبدیل تاریخ میلادی، شمسی با مبدل JDF در PHP


یه سوالی داشتم همونطور که در پاسخ یکی از کاربران گفتید
***********
پاسخ:
بهتر بود ابتدا سوال را با جزئیات مطرح می کردید که راهنمایی ما دقیق تر باشد، به هر صورت برای این کار نیازی نیست در فایل txt آدرس url را ذخیره کنید، راه ساده تر آن ایجاد یک پوشه برای هر کاربر (نام پوشه می تواند آدرس url کاربر باشد) و مدیریت اطلاعات آماری او داخل آن پوشه است،
***********
برای استفاده از این روش باید چه کدی ایجاد شود که با فراخوانی ان کد از فایلی که ایجاد کرده ایم مثلا AMAR.PHP یک کپی جدید به نام AMAR2.PHP ایجاد کرد؟ تا بعدا بتوان با متد get فایل مورد نظر فراخوانی شود؟
با تشکر
قاعدتا نمی توانیم همه مراحل را در این قسمت شرح دهیم، در کل باید با توابع مربوط به فایل در PHP مانند copy، rename، unlink و... آشنا باشید، در واقع اگر می خواهید یک برنامه کاربردی بنویسید باید در سطح متوسط به بالا با PHP کار کرده باشید!
http://fr2.php.net/manual/en/function.copy.php
<?php echo $_SERVER['REMOTE_ADDR']; ?>
قاعدتا با اندکی آشنایی با PHP، به شیوه های مختلف می توانید از این پارامتر در برنامه خود استفاده کنید.اینم کدش فقط 2 تا علامت اضافه کردم.
<?php
$con = mysql_connect("localhost","root","");
if (!$con)
{
die('could not' .mysql_error());
}
mysql_select_db("mataleb",$con);
$wof = $_POST['t1'];
$result = mysql_query("SELECT * FROM texes where Title = '$wof'");
if (!$result)
{
die('could not' .mysql_error());
}
while($row = mysql_fetch_array($result))
{
echo $row['ID']."".$row['Text'];
echo "<br>";
}
mysql_close($con);
?>
با این کد ها معلوم میشه فقط یه اشتباه کوچک 3 هفته ادمو الاف می کنه- در یادداشت اول بحث آرایه را مطرح کردید اما در یادداشت دوم از حالت عادی استفاده شده!
- من یه فایلی درست کردم با فرم که اطلاعاتی رو به صفحه دیگر میفرسته. در صفحه دیگر می خوام به پایگاه داده متصل بشه و در یک جدول رکوردی رو انتخاب کنه که مثلا:
select * from tab where name="dd"
دی دی (dd) همون اطلاعات دریافت شده از صفحه قبلی است. این کد رو نوشتم ولی بخش آرایه اون جواب نمیده چرا؟<?php
$con = mysql_connect("localhost","root","");
if (!$con)
{
die('could not' .mysql_error());
}
mysql_select_db("mataleb",$con);
$wof = $_POST['t1'];
$result = mysql_query("SELECT * FROM texes where Title in ($wof)");
while($row = MYSQL_FETCH_array($result, MYSQL_ASSOC))
{
echo $row['ID']."".$row['Text'];
echo "<br>";
}
mysql_close($con);
?>
در مورد مشکل، syntax دستور IN در MySQL به صورت نمونه زیر است:
SELECT * FROM `Table` WHERE `id` IN (1, 2, 3)
یعنی آرایه به صورت مستقیم قابل استفاده نیست، باید به طور مثال به روش زیر به صورت رشته جدا شده با علامت , تبدیل شود:<?php
$array = array(1, 2, 3);
$array2 = "'" . join(', ',$array) . "'";
$query = "SELECT * FROM table WHERE id IN ($array2)";
?>
PHP در سرور اجرا می شود و دسترسی مستقیم به سیستم کاربر وجود ندارد، تنها اطلاعاتی که می توان بدست آورد همان است که از طریق مرورگرها به سرور ارسال می شود (مانند IP، نوع سیستم عامل، نام و نسخه مرورگر و...). لذا امکان به دست آوردن مشخصات سخت افزاری از این طریق وجود ندارد.
میشه لطف کنید کدی که فقط آنلاین و نشون بده بگید ؟
فقط آنلاین و نشون بده و بشه آنلاین رو تا 10 دقیقه قبل نشون بده.
+ این کدی که گذاشتید آنلاین هاش واسه من اشتباه حساب می کنه چرا ؟ :s
لطفا کد آنلاین و برام بزارید . بازم ممنون . یا علی
تا جایی که ما در حین نوشتن کدها و تهیه آموزش تست کرده ایم، مشکلی در این کد وجود ندارد، با این حال حل مشکل شما نیاز به تست و آزمایش و خطا در محیط سایتتان دارد، در مورد اینکه صرفا آنلاین ها را نمایش دهد، این کد در دو قسمت (تعداد بازدید و افراد آنلاین) کاملا از هم جدا است و با کمی آشنایی با PHP می توانید موارد اضافه را حذف کنید، حتی در صورتی که قادر به این کار نبودید، بخش echo مربوط به گرفتن خروجی را حذف کنید تا فقط افراد آنلاین چاپ شود.
حذف شد
کدهای PHP قاعدتا نباید در جای بخصوصی ثبت شوند!، استفاده از این آموزش (کاربردی) مسلزم آشنایی اولیه با مباحث مقدماتی است، در این صورت می دانیم که کدهای PHP در یک فایل با پسوند php ذخیره و در سرور اجرا یا در سایر فایل های PHP وارد یا به اصطلاح include می شوند.
در شرایطی ممکن است چنین اتفاقی رخ دهد (جهت اطمینان همان کار را یک بار دیگر تست کنید)، اگر تغییر نام دایرکتوری منجر به این شود که اطلاعات در یک مسیر دیگر ذخیره گردند، قاعدتا آمار قبلی از دست می رود.
و این نکته رو بگم که چون روی سرور افلاین چک کردم دسترسی به permission نداشتم تا فایل رو 0755 قرار بدم!
و نکته بعدی اینکه من فقط بازدید کل رو نیاز داشتم برای همین در فایل php خط
$total_visit
رو فراخوانی کردم.اگر ممکنه راهنمایی بفرمایید دلیل اینکه امار بازدید چرا از 505 به 21 تغییر کرده؟ ایا رو سرور آنلاین ممکنه همچین مشکلی پیش بیاد و همه امار کل بازدید از بین بره؟ با تشکر
اگر مشکلی در به روزرسانی اطلاعات فایل متنی وجود نداشته باشد، مشکلی نیز در ثبت و افزایش آمار ایجاد نمی شود، دلیل خاصی وجود ندارد که آمار یکباره بازگشت به عقب کند! مگر اینکه فایل ناقص یا به اشتباه ویرایش شده باشد، یا به فرض تاریخ سیستم دستکاری شود، در هر صورت به صورت دستی می توان تغییرات ناخواسته را اصلاح و عددها را تنظیم کرد، چیز خاصی از بین نمی رود!
متاسفانه کد آماده در اختیار نداریم، باید کد را از سایت های ارائه دهنده اسکریپت، دانلود یا اینکه خودتان بنویسید.
اگر بخوام این آمارگیر رو تو سایت استفاده کنم تو صفحه اصلی که کاربران هم ببینن باید چیکار کنم؟
از این لحاظ که تو visitor-online.txt آی پی کاربران رو نشون میده خطرناک نیست ؟
حالت نمایش با echo امکانپذیر است، اما برای حفظ امنیت هم می توانید نام فایل ها را به صورت عبارت نامفهومی تغییر دهید هم اینکه با دستورات htaccess دسترسی به آنها را محدود کنید، مثال:
RewriteRule ^(visitor-online\.txt) - [F,L,NC]
"- در گام بعدی بررسی می کنیم تا ببینیم آیا تاریخ آخرین ویرایش فایل برابر تاریخ امروز است یا خیر، اگر این طور باشد بازدید امروز و بازدید کل باید افزایش یابند، اما اگر تاریخ امروز با تاریخ آخرین ویرایش تفاوت کند، پس محاسبه بازدیدها وارد یک روز جدید شده و آمار فعلی باید به عنوان آمار دیروز در نظر گرفته شوند و بازدید امروز نیز از نو شروع شده و نهایتا بازدید کل نیز افزایش یابد (درک صحیح عملکرد اسکریپت با کمی تامل و آشنایی با مبحث آرایه ها آسان می گردد)."
دوستان پرسیدن که میشه جای دیگه نمایش داد. من کاملا متوجه نشدم من اگر بخوام آمار سایتم و به جای اینکه توی صفحه ی اصلی سایتم نمایش بدم توی پنل ادمین و فقط برای ادمین بخوام نمایش بدم باید این کد و توی صفحه ی اصلی سایتم داشته باشم؟
- به سوالات کلی، زمانبر، مبهم و مشکلاتی که تلاشی برای رفع آنها نکرده باشید پاسخ مختصر داده شده یا به بخش برنامه نویسی اختصاصی ارجاع داده می شوند.
- کدها و اسکریپت های طولانی را ترجیحا در یک صفحه وب آنلاین یا به صورت حساب موقت و آزمایشی قرار دهید تا امکان بررسی دقیق مشکل و خطایابی میسر باشد.
- تمام دیدگاه های ارسالی خوانده شده و برای هر کاربر مدت زمان لازم جهت پاسخگویی در نظر گرفته می شود، لطفا از طرح سوالات متعدد در بازه زمانی کوتاه خودداری کنید.