نمایش نتایج: از شماره 1 تا 10 , از مجموع 12

موضوع: درخواست تغییر در این کد php برای آپلود فایل

Threaded View

پست قبلی پست قبلی   پست بعدی پست بعدی
  1. #2
    عضو انجمن M.Abooali آواتار ها
    تاریخ عضویت
    Apr 2013
    محل سکونت
    Shiraz
    نوشته ها
    269
    تشکر تشکر کرده 
    149
    تشکر تشکر شده 
    841
    تشکر شده در
    385 پست

    پیش فرض پاسخ : درخواست تغییر در این کد php برای آپلود فایل

    البته اصلا شیوه آپلود شما به درستی بررسی کننده Mime/type فایل ها نیست و به سادگی میشود دورش زد و عملا امنیت بسیار پایینی داره این شیوه کنترل پسوند ها.

    شما این خط را پیدا کنید:

    کد PHP:
           $uploadfile $uploaddir $id '.gif'
    آن را حذف و جاش این کدها را بزارید:
    کد PHP:
          $image getimagesize($_FILES['pic']['tmp_name']);
          
    $file_ext $image['mime'];
          
          if (
    $file_ext='image/gif') {
             
    $uploadfile $uploaddir $id '.gif';
          } 
          elseif (
    $file_ext='application/zip'
          {
             
    $uploadfile $uploaddir $id '.zip';
          } 
          elseif (
    $file_ext='application/x-rar-compressed'
          {
             
    $uploadfile $uploaddir $id '.rar';
          } 
          else 
          {
    die(
    'پسوند فایل ها صحیح نمی باشد!');
          } 
    با کد بالا ما اول پسوند فایل را کشف و برابر متغیر file_ext قرار دادیم.

    البته شیوه های دیگه ای هم هست برای کشف پسوند، اما این شیوه نه به نصب بود image_gd روی سرور نیاز دارد، و نه تابع مرورگر است (قابل دور زدن به راحتی نیست).

    سپس با قیاس type فایل، پسوند مورد نظر را به انتهای نامش اضاف میکنیم.

    من براتون 3 تا پسوند را گذاشتم، اگر خواستید می توانید دیگر پسوند ها را نیز مجاز کنید، کافیست شرط جدید برای اون پسوند به کد اضاف کنید، این هم Mime/type های پر کاربرد:

    کد PHP:
                'txt' => 'text/plain',
                
    'htm' => 'text/html',
                
    'html' => 'text/html',
                
    'php' => 'text/html',
                
    'css' => 'text/css',
                
    'js' => 'application/javascript',
                
    'json' => 'application/json',
                
    'xml' => 'application/xml',
                
    'swf' => 'application/x-shockwave-flash',
                
    'flv' => 'video/x-flv',

                
    // images
                
    'png' => 'image/png',
                
    'jpe' => 'image/jpeg',
                
    'jpeg' => 'image/jpeg',
                
    'jpg' => 'image/jpeg',
                
    'gif' => 'image/gif',
                
    'bmp' => 'image/bmp',
                
    'ico' => 'image/vnd.microsoft.icon',
                
    'tiff' => 'image/tiff',
                
    'tif' => 'image/tiff',
                
    'svg' => 'image/svg+xml',
                
    'svgz' => 'image/svg+xml',

                
    // archives
                
    'zip' => 'application/zip',
                
    'rar' => 'application/x-rar-compressed',
                
    'exe' => 'application/x-msdownload',
                
    'msi' => 'application/x-msdownload',
                
    'cab' => 'application/vnd.ms-cab-compressed',

                
    // audio/video
                
    'mp3' => 'audio/mpeg',
                
    'qt' => 'video/quicktime',
                
    'mov' => 'video/quicktime',

                
    // adobe
                
    'pdf' => 'application/pdf',
                
    'psd' => 'image/vnd.adobe.photoshop',
                
    'ai' => 'application/postscript',
                
    'eps' => 'application/postscript',
                
    'ps' => 'application/postscript',

                
    // ms office
                
    'doc' => 'application/msword',
                
    'rtf' => 'application/rtf',
                
    'xls' => 'application/vnd.ms-excel',
                
    'ppt' => 'application/vnd.ms-powerpoint',

                
    // open office
                
    'odt' => 'application/vnd.oasis.opendocument.text',
                
    'ods' => 'application/vnd.oasis.opendocument.spreadsheet'
    البته اگر بیش از 5 مورد خواستید استفاده کنید بهتره از array یا توابع کامل تر بهره ببرید که بیخود اسکریپت سنگین نشود.

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


    - - - Updated - - -

    امیدوارم کدها جواب دهد، چون اسکریپت کامل شما اینجا نیست، امکان تست نبود.

    چون پروژه دانشگاه هست، قسمت دوم درخواست را گذاشتم خودتان با نگاه به کدهای قسمت اول کشف کنید.
    ویرایش توسط M.Abooali : May 17th, 2014 در ساعت 14:53
    [ فعالیت تجاری در اینجا ندارم | پاسخ سوالات فقط در تاپیک | اطلاعات بیشتر درباره من: https://abooali.ir ]

  2. تعداد تشکر ها ازM.Abooali به دلیل پست مفید


اطلاعات موضوع

کاربرانی که در حال مشاهده این موضوع هستند

در حال حاضر 1 کاربر در حال مشاهده این موضوع است. (0 کاربران و 1 مهمان ها)

موضوعات مشابه

  1. رقصیدن با گوگل: تغییر، تغییر و باز هم تغییر در الگوریتم
    توسط sibait در انجمن مباحث و منابع آموزشی
    پاسخ ها: 0
    آخرين نوشته: July 16th, 2017, 04:22
  2. پاسخ ها: 0
    آخرين نوشته: January 10th, 2017, 16:13
  3. بعد از تغییر ip ــیِ لایسنس ، cid و lid تغییر پیدا می کنه؟
    توسط mha1368 در انجمن دايرکت ادمين DirectAdmin
    پاسخ ها: 8
    آخرين نوشته: September 24th, 2015, 23:43
  4. در خواست کمک برای تغییر تنظیمات کلوکسو بعد از تغییر ایپی اصلی vps
    توسط cacodemon در انجمن کلوکسو يا ال ايکس ادمين Kloxo or LXAdmin
    پاسخ ها: 10
    آخرين نوشته: June 16th, 2013, 14:50
  5. تغییر timezone وب سایت در .htaccess - تغییر زمان
    توسط irmizban در انجمن سی پنل CPanel
    پاسخ ها: 0
    آخرين نوشته: February 19th, 2012, 22:17

مجوز های ارسال و ویرایش

  • شما نمیتوانید موضوع جدیدی ارسال کنید
  • شما امکان ارسال پاسخ را ندارید
  • شما نمیتوانید فایل پیوست کنید.
  • شما نمیتوانید پست های خود را ویرایش کنید
  •