یکشنبه ۰۳ مرداد ۱۴۰۰

Sunday, July 25, 2021 GMT +4:30

» ایجاد لینک دانلود مدت دار با PHP و MySQL

mysql-php-limit-download

احتمالا تا به حال سایت هایی را دیده اید که لینک دانلود آنها به اصطلاح مدت دار بوده و پس از گذشت چند ساعت یا چند روز دیگر نمی توان با آن لینک، فایل مورد نظر را دانلود کرد، این سیستم به انگیزه های مختلف ممکن است مورد نیاز باشد، از جمله اینکه می توان بین کاربران مختلف با توجه به حالت دانلود (رایگان یا با پرداخت هزینه) تفاوت قائل شد، یا هر زمان که نیاز بود، بدون حذف فیزیکی فایل از سرور، لینک دانلود آن را غیر فعال کرد، همچنین این حالت معمولا باعث جلوگیری از بروز ترافیک سنگین و درخواست های متعدد برای دانلود فایل ها می شود که این خود بر بهبود عملکرد سرویس های دانلود تاثیر مثبت دارد، به هر صورت فارغ از انگیزه شما برای انجام این کار، در ادامه آموزش، خواهیم دید که چگونه می توان با کمک PHP و MySQL، سیستم ایجاد لینک دانلود مدت دار را طراحی نمود.

ایجاد دیتابیس و جداول لازم


طبق معمول برنامه های مبتنی بر دیتابیس MySQL، اولین گام ما ایجاد و تعریف ساختار پایگاه داده است که در اینجا با توجه به نیازمان ابتدا از طریق برنامه phpMyAdmin یا با استفاده از کدهای PHP، دیتابیس download را می سازیم (در این آموزش فرض بر این است که از طریق برنامه phpMyAdmin پایگاه داده را ساخته اید)، سپس کدهای زیر را (در صورت نیاز پس از اعمال تنظیمات اتصال) در دایرکتوری فرضی time-limit-download و با نام table_create.php در ریشه هاست یا در سرور مجازی اجرا می کنیم (باید این دایرکتوری را در فولدر www یا public_html و فایل را داخل آن داشته باشید).
<!doctype html>
<html>
<head>
<meta charset="utf-8">
<title>وبگو | ساخت جدول دانلود مدت دار فایل</title>
<!-- https://webgoo.ir -->
<style type="text/css">
body{
    font-family:Tahoma, Geneva, sans-serif;
    font-size:12px;
    direction:rtl;
}
.ltr{
    direction:ltr;
}
</style>
</head>
<body>
<?php
@$con = mysqli_connect('localhost', 'root', '', 'download');
//خطای اتصال
if(mysqli_connect_errno()){
    echo 'اتصال با دیتابیس برقرار نشد:
    <br>
    <div class="ltr">
    '
.mysqli_connect_errno().' - '.mysqli_connect_error().'
    </div>'
;
}
//اتصال برقرار است
else{
    $query = mysqli_query($con, "CREATE TABLE file_storage(
    id INT NOT NULL AUTO_INCREMENT,
    PRIMARY KEY(id),
    client_ip VARCHAR(255),    
    original_name VARCHAR(255),
    temp_name VARCHAR(255),
    date_time BIGINT(20)) ENGINE=MyISAM"
);

    if(mysqli_errno($con)){
        echo 'بروز خطا در ایجاد جدول:
        <br>
        <div class="ltr">'
.mysqli_errno($con).' - '.mysqli_error($con).'</div>';        
    }
    else{
        $link = 'http://'.$_SERVER["SERVER_NAME"].'/time-limit-download/test.zip';
        echo 'جدول با موفقیت ساخته شد.
        <br>
        <div class="ltr">
        <a href="'.$link.'">'
.$link.'</a>
        </div>'
;
    }
}

$close = mysqli_close($con);
?>
</body>
</html>
لینک اجرای فایل باید مطابق با نمونه زیر باشد.
http://localhost/time-limit-download/table_create.php
نکته: در این آموزش از اکستنشن mysqli استفاده شده که می توانید مطابق سلیقه از PDO یا حتی اکستنش اولیه mysql استفاده کنید (استفاده از این اکستنشن به جزء در موارد آموزشی و پروژه های قدیمی، توصیه نمی شود).
توضیح:
با اجرای فایل بالا جدولی با نام فرضی file_storage در دیتابیس download ایجاد می شود که این جدول دارای ستون هایی است که در قسمت CREATE TABLE پرس و جوی بالا ملاحظه می کنید، در زیر به صورت مختصر و جهت آشنایی نقش ستون ها را بررسی می کنیم.
ستون id: این ستون به عنوان یک شماره یکتا معمولا در اکثر برنامه های مبتنی بر دیتابیس استفاده می شود (جهت تمایز و مدیریت بهتر داده های مختلف)، نوع این ستون INT است که در این حالت تا مرز 2147483647 ردیف قابل ایجاد است.
ستون client_ip: این ستون برای نگهداری IP کاربر است که در هنگام تطبیق اطلاعات لینک می تواند مورد استفاده قرار گیرد (استفاده از IP صرفا جهت نمونه است و در صورت نیاز می تواند استفاده نشود).
ستون original_name: این ستون نام اصلی فایل را به همراه پسوند آن نگهداری می کند.
ستون temp_name: این ستون برای نگهداری نام hash شده فایل است (hash به عبارت رمزی شده گفته می شود که در مورد استفاده ما به آن token نیز گفته می شود).
ستون date_time: این ستون جهت نگهداری تاریخ و زمان با نمونه فرمت 20140101121110 (ثانیه دقیقه ساعت روز ماه سال) است، از این عدد برای محاسبه مدت زمان انقضای لینک دانلود استفاده می کنیم.

ایجاد لینک دانلود


پس از ایجاد دیتابیس و جدول، اکنون باید کدی داشته باشیم که آدرس های موقت دانلود مدت دار فایل را برایمان ایجاد کند، در واقع در این مرحله به طور مثال کاربر لینک فرضی زیر را از سرور درخواست می کند و در پاسخ، لینک مدت دار به او نشان داده می شود.
نمونه لینک درخواستی کاربر:
http://localhost/time-limit-download/test.zip
نمونه آدرس ایجاد شده برای دانلود مدت دار:
http://localhost/time-limit-download/gCvHGkaDADuTbmq3dQsdSXyZ/test.zip
لذا کدهای زیر را در فایلی با نام download_link.php در دایرکتوری time-limit-download درج کنید.
<!doctype html>
<html>
<head>
<meta charset="utf-8">
<title>وبگو | ایجاد لینک دانلود مدت دار</title>
<!-- https://webgoo.ir -->
<style type="text/css">
body{
    font-family:Tahoma, Geneva, sans-serif;
    font-size:12px;
    direction:rtl;
}
.ltr{
    direction:ltr;
}
</style>
</head>
<body>
<?php
//تابعی برای ایجاد عبارت رندوم
function randomStr($length){
    $characters = '0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ';
    $random_string = '';
    for($i = 0; $i < $length; $i++){
        $random_string .= $characters[rand(0, strlen($characters) - 1)];
    }
    return $random_string;
}

@$file = $_GET['file'];
if(!isset($file)){
    echo 'مشکلی در دریافت اطلاعات فایل وجود دارد!';
}
else{
    @$con = mysqli_connect('localhost', 'root', '', 'download');
    //خطای اتصال
    if(mysqli_connect_errno()){
        echo 'اتصال با دیتابیس برقرار نشد:
        <br>
        <div class="ltr">
        '
.mysqli_connect_errno().' - '.mysqli_connect_error().'
        </div>'
;
    }
    //اتصال برقرار است
    else{
        $temp = randomStr(24);
        $date = date('YmdHis');
        //مدت زمان اعتبار لینک به ثانیه
        $time = date('YmdHis', time() - 60);
        //ایمن سازی
        $file = mysqli_real_escape_string($con, $file);
        $ip = mysqli_real_escape_string($con, $_SERVER["SERVER_ADDR"]);
        
        //حذف ردیف هایی که تاریخ اعتبار آنها گذشته است
        $query = mysqli_query($con, "DELETE FROM file_storage WHERE date_time < '$time'");
                
        //بررسی ip
        $query = mysqli_query($con, "SELECT temp_name FROM file_storage WHERE client_ip = '$ip' AND original_name = '$file' LIMIT 1");
        $count = mysqli_num_rows($query);
        //استفاده از لینک موجود
        if($count > 0){
            while($row = mysqli_fetch_array($query)){
                $temp = $row['temp_name'];
                //آپدیت زمان
                $update = mysqli_query($con, "UPDATE file_storage SET date_time = '$date' WHERE client_ip = '$ip' AND original_name = '$file' LIMIT 1");
            }
        }
        //ایجاد لینک جدید
        else{
            $query = mysqli_query($con, "INSERT INTO file_storage(
            client_ip, original_name, temp_name, date_time)
            VALUES('"
.$ip."', '".$file."', '".$temp."', '".$date."')");
        }
        
        if(mysqli_errno($con)){
            echo 'بروز خطا در ذخیره و ایجاد لینک دانلود:
            <br><div class="ltr">'
.mysqli_errno($con).' - '.mysqli_error($con).'</div>';
        }
        else{
            $link = 'http://'.$_SERVER["SERVER_NAME"].'/time-limit-download/'.$temp.'/'.$file.'';
            echo 'لینک دانلود با موفقیت ساخته شد:
            <br>
            <div class="ltr">
            <a href="'.$link.'">'
.$link.'</a>
            </div>'
;
        }
    }
    
    $close = mysqli_close($con);    
}
?>
</body>
</html>
توضیح:
منطق به کار رفته در این قسمت خیلی پیچیده نیست، ابتدا فایل درخواستی کاربر از سرور از طریق متد GET دریافت شده و پیش از ایجاد لینک جدید، وجود IP کاربر و نام فایل مشابه در دیتابیس بررسی می شود، اگر فایل مشابهی با این IP در دیتابیس باشد، ضمن به روز رسانی مدت زمان اعتبار لینک، از اطلاعات موجود برای نمایش لینک دانلود مدت دار استفاده می شود، در غیر این صورت (یعنی اگر اطلاعاتی مطابق با IP و نام اصلی فایل در دیتابیس موجود نباشد)، لینکی با اطلاعات جدید ساخته و در دیتابیس نیز INSERT می شود.
نکته 1: ملاحظه می کنید که پیش از هر گونه اقدامی، ابتدا دستور حذف ردیف های تاریخ گذشته را اجرا کرده ایم.
نکته 2: مدت اعتبار لینک با تغییر مقادیر عددی در متغیر time قابل تغییر است، در این مثال ما از عدد 60 ثانیه استفاده کرده ایم که می توان مطابق نیاز آن را افزایش یا احیانا کاهش داد.
نکته 3: بررسی وجود IP و لینک موجود به این دلیل ممکن است ضروری باشد که معمولا علاوه بر مرورگر، برنامه های مدیریت دانلود مانند IDM نیز (هم زمان با مرورگر و به صورت مخفیانه) درخواستی به سرور ارسال می کنند که در این صورت برای یک فایل، دو ردیف و دو لینک دانلود مجزا در دیتابیس خواهیم داشت که قاعدتا یک مورد آن زائد است.
نکته 4: همان طور که پیش تر گفته شد، این برنامه صرفا یک الگو است و می توان بر اساس نیاز خود بخش هایی از آن را حذف یا مواردی اضافه نمود (منتها باید نسبت به انجام این مورد مسلط باشید!).

ایجاد فولدر file و کد اجرای دانلود


پس از ایجاد و ذخیره لینک دانلود مدت دار، قاعدتا این لینک باید توسط کاربر نهایی جهت دانلود فایل استفاده شود، لذا بدین منظور در دایرکتوری time-limit-download فولدر دیگری با نام file ساخته و درون آن فایلی با نام download_file.php می سازیم، کدهای این فایل وظیفه بررسی لینک درخواستی و در صورت تائید، ارسال فایل به مرورگر را به عهده خواهند داشت.
<!doctype html>
<html>
<head>
<meta charset="utf-8">
<title>وبگو | دانلود فایل مدت دار</title>
<!-- https://webgoo.ir -->
<style type="text/css">
body{
    font-family:Tahoma, Geneva, sans-serif;
    font-size:12px;
    direction:rtl;
}
.ltr{
    direction:ltr;
}
</style>
</head>
<body>
<?php
@$token = $_GET['token'];
@$file = $_GET['file'];
if(!isset($file) || !isset($token)){
    echo 'مشکلی در دریافت اطلاعات فایل وجود دارد!';
}
else{
    @$con = mysqli_connect('localhost', 'root', '', 'download');
    //خطای اتصال
    if(mysqli_connect_errno()){
        echo 'اتصال با دیتابیس برقرار نشد:
        <br>
        <div class="ltr">
        '
.mysqli_connect_errno().' - '.mysqli_connect_error().'
        </div>'
;
    }
    //اتصال برقرار است
    else{
        $date = date('YmdHis');
        //مدت زمان اعتبار لینک به ثانیه
        $time = date('YmdHis', time() - 60);
        //ایمن سازی
        $token = mysqli_real_escape_string($con, $token);        
        $file = mysqli_real_escape_string($con, $file);
        
        //حذف ردیف هایی که تاریخ اعتبار آنها گذشته است
        $query = mysqli_query($con, "DELETE FROM file_storage WHERE date_time < '$time'");
        
        //بررسی اطلاعات فایل درخواستی کاربر با سرور
        $query = mysqli_query($con, "SELECT temp_name FROM file_storage WHERE original_name = '$file' AND temp_name = '$token' LIMIT 1");
        $count = mysqli_num_rows($query);
        //اطلاعات فایل معتبر است
        if($count > 0){
            //تابع برای بدست آوردن پسوند فایل
            function getExtension($file){
                preg_match('/\.[^\.]+$/i', $file, $ext);
                return $ext[0];
            }
            
            //نوع فایل
            $file_type = NULL;
            switch(getExtension($file_name)){
                case 'zip':
                $file_type = 'application/zip';
                break;
                case 'pdf':
                $file_type = 'application/pdf';
                break;
                case 'jpg':
                $file_type = 'image/jpeg';
                break;
            }
            
            //ارسال فایل به مرورگر برای دانلود
            $file_name = $file;
            header('Content-Description: File Transfer');
            //header('Content-Type: application/octet-stream');
            header('Content-Type: '.$file_type);
            header('Content-Disposition: attachment; filename='.$file_name);
            header('Content-Transfer-Encoding: binary');
            header('Expires: 0');
            header('Cache-Control: must-revalidate, post-check=0, pre-check=0');
            header('Pragma: public');
            header('Content-Length: '.filesize("$file_name"));
            ob_clean();
            flush();
            readfile("$file_name");
        }
        //لینک فایل معتبر نیست یا فایل حذف شده
        else{
            echo 'فایل مورد نظر یافت نشد!';
        }
    }
    
    $close = mysqli_close($con);
}
?>
</body>
</html>
توضیح:
عملکرد این کد به این صورت است که پارامتر hash یا همان token ارسالی از کاربر و همچنین نام حقیقی فایل را که از طریق لینک مدت دار دانلود دریافت شده با دیتابیس تطبیق داده و در صورتی که اطلاعات معتبر باشد، فایل موجود در دایرکتوری file را به مرورگر (یا هر واسط کاربری دیگر مانند برنامه های مدیریت دانلود) ارسال می کند.
نکته: لطفا برای کسب اطلاعات بیشتر در خصوص این قسمت از آموزش، مطلب مشابه ای را که پیش تر در سایت منتشر شده مطالعه کنید:
محدود کردن لینک دانلود مستقیم فایل ها با PHP و htaccess

دستور htaccess برای ایجاد لینک های استاتیک


در آخرین گام از ایجاد لینک دانلود مدت دار نیاز به دستورات htaccess زیر در ریشه سایت است تا بتوانیم آدرس های استاتیک (آدرس هایی که در آنها علامت ? نباشد) را ایجاد و استفاده کنیم، لذا بدین منظور اگر فایل htaccess. در ریشه سایت وجود دارد، کافی است دستورات جدید را در انتها اضافه کنید، اما اگر این فایل وجود ندارد باید آن را بسازید و کدها را در آن درج نمائید.
RewriteEngine on
RewriteRule time-limit-download/([^/]+)/([^/]+)(\.zip|\.pdf|\.jpg)$ /time-limit-download/file/download_file.php?token=$1&file=$2$3 [NC,L]
RewriteRule time-limit-download/([^/]+)(\.zip|\.pdf|\.jpg)$ /time-limit-download/download_link.php?file=$1$2 [NC,L]
دو دستور بالا به ترتیب برای دریافت لینک مدت دار (token و نام اصلی فایل) و لینک عادی فایل (بدون token) کاربرد دارد.
نکته: اگر از فعال بودن Rewrite Engine در سرور مجازی خود مطمئن نیستید، لطفا در این خصوص در وب جستجو کنید.

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


دانلود نمونه فایل های آموزش ایجاد لینک دانلود مدت دار با PHP و MySQL
دسته بندی: آموزش کاربردی » MySQL
related مطالب بیشتر:
» آموزش ساخت فرم عضویت در سایت با PHP و MySQL
» تعویض کد امنیتی Captcha با Ajax و MySQL
» آموزش حذف گروهی اطلاعات از MySQL با استفاده از چک باکس
» جستجو در مطالب سایت با استفاده از MySQL Full-Text
» هوشمند سازی پنل ورود و خروج سایت با PHP و MySQL
commentنظرات (۵۴ یادداشت برای این مطلب ارسال شده است)
more یادداشت های جدید بر اساس تاریخ ارسال در انتهای یادداشت های موجود نمایش داده می شوند.
نویسنده: محمد حسین
۱۲:۰۶ ۱۳۹۳/۰۳/۰۷
خیلی عالی :x
نویسنده: محمد
۱۴:۲۵ ۱۳۹۳/۰۳/۰۹
مفید بود ممنون
نویسنده: Alireza
۲۱:۱۹ ۱۳۹۳/۰۳/۱۹
چه عجب اپدیت شدید :D
نسخه جدید سایتتون کی قراره بیاد ؟؟
پاسخ: 
نه خیلی زود و نه خیلی دیر :-)
نویسنده: Arya
۱۶:۰۳ ۱۳۹۳/۰۳/۲۱
سلام - هاست دانلود من ديتابيس نداره ، راه ديگه اى وجود ندارد!؟؟
پاسخ: 
سلام
راه آسانی وجود ندارد!
می توان با برنامه نویسی اطلاعات را در یک فایل متنی مدیریت کرد، منتها این روش بسیار پیچیده خواهد بود و به سادگی قابل آموزش نیست.
نویسنده: حسین
۱۸:۰۹ ۱۳۹۳/۰۳/۲۹
سلام من یه سوال دارم اون هم اینه که برای فایل های متنی چگونه لینک دانلود بزاریم چون وقتی واسه اون ها لینک درست می کنم وقتی کلیک می کنم اون را تو مرورگر نشون میده دانلود نمیاره. البته من با فرمت Cfg و db کار کردم.
با تشکر
پاسخ: 
سلام
فایل ها را به صورت zip فشرده کنید!
نویسنده: مسعود
۱۴:۵۴ ۱۳۹۳/۰۴/۰۶
سلام
من در هاست یک دیتابیس با ساختم و فایل ضمیمه رو در اون ریختم
اما 100% مشکل دارم چون فایل ها دانلود میشن اما به صورت دائم
میشه بیشتر توضیح بدید؟
پاسخ: 
سلام
متاسفانه بدون تست نمی توان گفت مشکل کار کجا است، ممکن است از htaccess یا موارد دیگری باشد.
نویسنده: morteza
۲۲:۱۹ ۱۳۹۳/۰۴/۱۲
با سلام
نماز و روزه هاتون قبول باشه. خییییلی عالی بود.
با تشکر فراوان
نویسنده: بهاره
۱۱:۱۹ ۱۳۹۳/۰۴/۲۳
با سلام
سپاس از مطالب بسیار خوبتون . من مراحل طراحی سایتی رو تکمیل کردم و سایت آماده شده . ناگفته نمونه که از مطالب شما هم استفاده کردم. سوالی که از خدمتتون داشتم اینه که برای تحویل دادن به مشتری و از اون جایی که مشتری درخواست یک پنل مدیریتی رو داشته باید یک cms جدا گانه برای سایتی که طراحی کردم، ایجاد کنم یا اینکه می تونم از cms هایی مثل ورد پرس استفاده کنم ؟
پاسخ: 
سلام
اگر منظور از سایت، پوسته ظاهری آن است، هم می توانید برای آن یک سیستم مدیریت بنویسید که قاعدتا کاری وقتگیر و حرفه ای است، و هم آن را به عنوان قالب، برای سیستم های موجود از جمله جوملا، وردپرس و... ترجمه و آماده کنید که این کار نیازمند آشنایی با CMS مورد نظر و نحوه طراحی قالب و امکانات برای آن است.
نویسنده: مهران
۱۲:۲۹ ۱۳۹۳/۰۴/۲۷
با سلام. من میخوام شروع کنم به نوشتن یه فروشگاه فایل به طوری که کاربر بعد از پرداخت بتونه فایل مورد نظر رو دانلود کنه. طبیعتا میخوام که اون لینک داینامیک باشه و مدت زمان محدودی هم قابل دانلود باشه. یه توضیح مختصری میخوام راجع به چگونگی ساختار بانکش و شروع برنامه نویسیش
پاسخ: 
سلام
سوال کلی است! در اینگونه موارد بهترین راهنما، تجربه است، باید تجربه قبلی نوشتن پروژه های کوچکتر را داشته باشید، ساختار دیتابیس بر اساس هدف شما تعریف می شود، اینکه به فرض برنامه شما به چه جداولی نیاز دارد یا هر جدول وظیفه ذخیره چه نوع اطلاعاتی را داشته باشد، نیاز به صرف وقت، تفکر و طراحی ساختار دارد، یک گزینه دیگر بررسی ساختار دیتابیس برنامه های آماده است که می تواند الگوی خوبی باشد.
نویسنده: علی
۲۰:۵۲ ۱۳۹۳/۰۵/۰۴
میشه یه آموزش هم در مورد ارسال درخواست دوستی بین کاربران که به دیتابیس هم متصل باشه بذارید تو سایت؟
و یه اموزش در مورد ارسال پیام خصوصی بین کاربران که اونم به دیتابیس متصل باشن
ممنون
پاسخ: 
دوست گرامی این مباحث طوری نیستند که بتوانیم در قالب آموزش مطرح کنیم، در ابتدا باید موارد مقدماتی را فرا بگیرید، سپس اینگونه امکانات را با کمی تجربه و خلاقیت می توان تعریف کرد!
نویسنده: پایان نامه
۱۵:۲۲ ۱۳۹۳/۰۵/۱۱
مطلب خیلی مفیدی بود دستتون درد نکنه
نویسنده: مهران
۱۵:۵۲ ۱۳۹۳/۰۵/۱۸
سلام
من تمام مراحل رو رفتم همش هم درسته لینک تولید میشه ولی وقتی من روی لینک کلیک میکنم از لاین 74 تا 82 یکی در میون این ارور رو میده
Warning: Cannot modify header information - headers already sent by (output started at /home/mtjbuxir/public_html/mtjtop.ir/time-limit-download/file/download_file.php:19) in /home/mtjbuxir/public_html/mtjtop.ir/time-limit-download/file/download_file.php on line 82
لطفا راهنمایی کنید
پاسخ: 
سلام
به نظر قبل از دستورات header خروجی (متنی یا به صورت کاراکتر مخفی) به مرورگر ارسال می کنید، این خروجی حتی می تواند شامل BOM باشد، برای حذف آن از برنامه Adobe Dreamweaver یا ++Notepad استفاده کرده و BOM را با ذخیره مجدد فایل حذف کنید (در نرم افزار ++Notepad باید از منوی Encoding و امکان Convert to UTF-8 without BOM استفاده کنید).
نویسنده: پارتیشن
۱۴:۴۷ ۱۳۹۳/۰۵/۲۱
خیلی عالی بود دستتون درد نکنه
نویسنده: میثم
۱۸:۵۹ ۱۳۹۳/۰۵/۲۴
سلام آموزش خیلی خوبی بود مرسی :)
کاش کدهای PHP رو با استایل نمایش بدید ;)
نویسنده: وحید
۲۰:۱۵ ۱۳۹۳/۰۶/۰۲
سلام.
من هم مشکل آقای مهران رو دارم.
منتها وقتی فایل رو با ++notepad باز میکنم Encoding روی Encode in UTF-8 without BOM هست ولی باز هم همون اررور های لاین 74 تا 82 رو مشاهده میکنم تا زمانی که 60 ثانیه میگذره و بعد پیغام میاد که فایل موجود نیست.
یعنی تا زمانی که لینک دانلود کار میکنه از خط 74 تا 82 اررور میده
پاسخ: 
سلام
- کدهای HTML موجود در ابتدای صفحه را پاک کرده و مجددا تست نمائید.
- قسمت
ob_clean();
flush();
را پاک کرده و تست نمائید.
در صورتی که مشکل با این روش ها حل نشود نیاز به بررسی با برنامه TeamViewer دارد.
more لطفا پیش از ارسال یادداشت نکات زیر را مد نظر داشته باشید:
- موارد غیرمرتبط با مباحث آموزش ها را در فرم منوی "تماس با ما" مطرح و پاسخ را از طریق ایمیل دریافت کنید.
- به سوالات کلی، مبهم و مشکلاتی که تلاشی برای رفع آن نکرده باشید پاسخ مختصر داده خواهد شد.
- کدها و اسکریپت های طولانی را ترجیحا در یک صفحه وب آنلاین قرار دهید تا امکان تست و بررسی وجود داشته باشد.
- از درج عناوین تبلیغاتی در فیلدها خودداری کنید، در صورتی که یادداشت تبلیغاتی تشخیص داده شود حذف خواهد شد.
- تمام یادداشت ها بررسی و زمانی جهت پاسخگویی در نظر گرفته می شود، لطفا از طرح سوالات متعدد خودداری کنید.





1 × 1
 refresh

آخرین دیدگاه ها
more برای دسترسی سریع به یادداشت مربوطه می توانید از لینک مطلب در کادر زیر استفاده کنید.
form آی تی
در:
ممنون آینده کاری پی اچ پی خوبه یا جاواسکریپت؟
۱۴۰۰/۰۴/۳۰

form رضا
در:
با عرض سلام و خسته نباشید ایا امکان این قضیه در outlook وجود دارد که ما ادرس فرستنده را از طریق آن بتوانیم پیدا...
۱۴۰۰/۰۴/۳۰

form محمود
در:
سلام مهندس چگونه می شود میزان حرکت اسکرول را تعیین کرد. یعنی با یه حرکت غلطک موس صفحه بعدی در کادر قرار بگیرد....
۱۴۰۰/۰۴/۳۰

form محمد
در:
سلام خیلی خیلی ممنون تشکر
۱۴۰۰/۰۴/۲۷

form محمود
در:
سلام چگونه حاشیه های ناتمام ایجاد کنیم. یعنی تمام دور کادر کامل نباشد و بردر دور کادر ناقص باشد. مثلن بردر سمت راست تا...
۱۴۰۰/۰۴/۲۷

form محمد
در:
سلام ببخشید من با curl میخواستم فایلی رو با api بفرستم ولی جواب نداد اگر امکانش هست تصحیحش کنید:
۱۴۰۰/۰۴/۲۷

form برنامه نویس
در:
سلام و عرض ادب خدمت استاد. یه سوال خدمت شما داشتم. چطور می تونیم از ادیتور مثل ckeditor یا tinymsc به جای textarea...
۱۴۰۰/۰۴/۲۷

form جواد
در:
با سلام من دانشی از برنامه نویسی ندارم ، میشه برنامه ای نوشت که آدرس یک صفحه بعد از لاگین شدن بهش داد و هر...
۱۴۰۰/۰۴/۲۱

form علی
در:
سلام خوبین؟ من میخوام برای وبلاگم سبد خرید بزنم ولی php و ........ بلد نیستم اگه برام درست کنین ممنونتون میشم
۱۴۰۰/۰۴/۱۹

form سینا الف
در:
باسلام! من از این آموزش‌ سایت‌تون هم خیلی استفاده کردم. ضمن تشکر صمیمانه از مدیریت وبگو بابت مطالب مفید و کاربری اش، سوالی درباره...
۱۴۰۰/۰۴/۱۸

form محمود
در:
سلام و تشکر از کمک های قبلی تان. در بخش بالا قسمت «تغییر رنگ پس زمینه با کلیک کاربرم» را خوندم . ولی کد...
۱۴۰۰/۰۴/۱۸

form محمود
در:
با سلام دوباره نمونه کدی که برای افکت پس زمینه چراغ پلیس و صدا قرار دادین خیلی خوب کار میکند و بسیار سپاس ....
۱۴۰۰/۰۴/۱۴

form احمد
در:
سلام خسته نباشید من یه کد نوشتم که قیمت کالا ها و نام کالا ها رو از یه صفحه برام استخراج کنه و بصورت جدول...
۱۴۰۰/۰۴/۱۴

form محمود
در:
سلام و عرض ادب چگونه می شود با کلیک روی یک متن ، کل پس زمینه در یک آن چشمک بزند یعنی رنگ...
۱۴۰۰/۰۴/۱۱

form مجید
در:
سلام. من برنامه ای دارم که بر اساس php و mysql کار میکنه. بهش 100 جمله میدم و جملات رو تصادفی نمایش میده. حالا میخام...
۱۴۰۰/۰۴/۱۰

form Amir
در:
خیلی عالی بود
۱۴۰۰/۰۴/۱۰

form Amir
در:
سلام ببخشید یک کانال تلگرامی است که سیگنال میده و شرطی اینکه در آلپاری و لایت فارسی حساب داشته باشی و تحت ای پی آنها...
۱۴۰۰/۰۴/۱۰

form مجید
در:
خیر ببینی جوون - این اسکرول افقی کلی اعصاب رو بهم ریخته بود .
۱۴۰۰/۰۴/۰۷

form جین مین
در:
با سلام و وقت بخیر من تمام مراحل رو به نظر خودم درست انجام دادم و فایل هم دانلود میشه اما مشکل اصلی اونجاست...
۱۴۰۰/۰۴/۰۶
  در انتظار بررسی: ۰
 پاسخگویی به سوالات ممکن است تا 24 ساعت زمان ببرد.