FuelPHP - फ़ाइल अपलोडिंग

फ़ाइल अपलोडिंग फॉर्म प्रोग्रामिंग में सबसे अधिक इस्तेमाल की जाने वाली सुविधाओं में से एक है। FuelPHP एक विशेष वर्ग प्रदान करता है,Uploadफ़ाइलों के अपलोड को संभालने के लिए। आइए इस अध्याय में अपलोड क्लास का उपयोग करके फ़ाइल अपलोड करने का तरीका जानें।

विन्यास

अपलोड क्लास को अलग कॉन्फ़िगरेशन फ़ाइल का उपयोग करके कॉन्फ़िगर किया जा सकता है, fuel/app/config/upload.php। महत्वपूर्ण विन्यास प्रविष्टियां इस प्रकार हैं -

  • max_size- अपलोड की जाने वाली फ़ाइल का अधिकतम आकार सेट करें। "0" असीमित अपलोड आकार को संदर्भित करता है

  • ext_whitelist - अनुमत फ़ाइल एक्सटेंशन सेट करें

  • ext_blacklist - अस्वीकृत फ़ाइल एक्सटेंशन सेट करें

  • type_whitelist- अनुमत फ़ाइल प्रकार सेट करें। उदाहरण के लिए, "टेक्स्ट" माइम के लिए "टेक्स्ट / प्लेन"

  • type_blacklist - अस्वीकृत फ़ाइल प्रकार सेट करें

  • mime_whitelist- अनुमत माइम फ़ाइल प्रकार सेट करें। उदाहरण के लिए, "पाठ / सादा"

  • mime_blacklist - अस्वीकृत माइम फ़ाइल प्रकार सेट करें

  • prefix - सर्वर पर अपलोड की गई फ़ाइल को सहेजते समय फ़ाइल नाम में उपसर्ग करने के लिए स्ट्रिंग

  • suffix - सर्वर पर अपलोड की गई फ़ाइल को सहेजते समय फ़ाइल नाम में प्रत्यय लगाने के लिए

  • extension - अपलोड की जाने वाली फ़ाइल का एक्सटेंशन सेट किया जाए

  • create_path - फाइल पथ बनाना है, यदि उपलब्ध नहीं है

  • overwrite - अपलोड की गई फ़ाइल को सहेजते समय मौजूदा फ़ाइल को अधिलेखित करना है या नहीं

  • auto_rename - अपलोड की गई फ़ाइल को सहेजते समय अनुक्रम संख्या जोड़कर फ़ाइल का नाम बदलना है या नहीं

  • randomize - अपलोड की गई फ़ाइल को सहेजने के लिए यादृच्छिक 32-वर्ण का नाम बनाना है या नहीं

तरीके अपलोड करें

अपलोड वर्ग उपयोगकर्ताओं द्वारा अपलोड की गई फ़ाइल को संसाधित करने और सहेजने के लिए विकल्प प्रदान करता है। प्रत्येक संसाधित फ़ाइल (सहेजने से पहले) में परिणाम सरणी में निम्न जानकारी होगी।

  • field - फॉर्म फील्ड का नाम

  • name - अपलोड की गई फ़ाइल का नाम

  • type - ब्राउज़र द्वारा परिभाषित फ़ाइल का प्रकार

  • mimetype - अपलोड वर्ग द्वारा परिभाषित फ़ाइल का प्रकार

  • file - अपलोड की गई फ़ाइल के अस्थायी स्थान का पूरी तरह से योग्य नाम

  • filename - अपलोड की गई फ़ाइल का नाम

  • extension - अपलोड की गई फ़ाइल का एक्सटेंशन

  • size - बाइट्स में अपलोड की गई फ़ाइल का आकार

  • errors - त्रुटि कोड और संदेश में त्रुटि की सरणी

  • error - अपलोड विफल होने के कारण सरणी त्रुटियां सेट करना है (अपलोड में विफलता के मामले में)

एक बार फाइल सर्वर में सेव हो जाने के बाद, परिणाम सरणी में निम्न जानकारी भी होगी।

  • saved_to - पूरी तरह से योग्य पथ जहां अपलोड की गई फ़ाइल सहेजी गई थी

  • saved_as - फ़ाइल का नाम जो सहेजा गया था

  • errors - अपडेटेड ऐरे सरणी

अब, अपलोड क्लास की विधि देखते हैं।

यह सही है

यदि कोई मान्य फ़ाइल उपयोगकर्ता द्वारा अपलोड की गई है, तो is_valid सही है।

// do we have any uploaded files to save? 
if (Upload::is_valid()) { 
   // process  
}

get_files

get_files सभी अपलोड की गई फ़ाइलों को बहु-आयामी सरणी के रूप में वापस करते हैं। यदि प्रपत्र के फ़ाइल इनपुट का एक सूचकांक / नाम निर्दिष्ट किया गया है, तो यह केवल निर्दिष्ट फ़ाइल इनपुट से संबंधित अपलोड की गई फ़ाइल वापस कर देगा।

foreach(Upload::get_files() as $file) { 
   // do something with the file info 
}  
if ( Upload::get_files(0)) { 
   // do something 
}

get_errors

यदि कोई एक या अधिक फ़ाइलें अपलोड करने में विफल रहता है, तो get_errors त्रुटियों की एक सरणी लौटाता है। यदि प्रपत्र के फ़ाइल इनपुट नाम का एक इंडेक्स / नाम निर्दिष्ट किया गया है, तो यह केवल निर्दिष्ट फ़ाइल इनपुट से संबंधित त्रुटि को वापस करेगा।

foreach(Upload::get_errors() as $file) { 
   // do something with the file info 
}  
if (Upload::get_errors('myimage')) { 
   // do something 
}

प्रोसेस

प्रक्रिया अपलोड फ़ाइल के बारे में जानकारी इकट्ठा करने की वास्तविक प्रक्रिया को संदर्भित करती है। हम सरणी का उपयोग करके एक नए कस्टम कॉन्फ़िगरेशन की आपूर्ति कर सकते हैं। यदि कोई कॉन्फ़िगरेशन निर्दिष्ट नहीं है, तो यह ईंधन / ऐप / कॉन्फ़िगरेशन / अपलोड.php में परिभाषित कॉन्फ़िगरेशन का उपयोग करेगा

Upload::process (array( 
   'auto_rename' => false, 
   'overwrite'   => true 
));

सहेजें

सहेजें एक उचित स्थान पर सभी मान्य फ़ाइलों को सहेजने की वास्तविक प्रक्रिया को संदर्भित करता है। हम केवल उस विशेष प्रविष्टि को बचाने के लिए सूचकांक को निर्दिष्ट कर सकते हैं।

Upload::save();
Upload::save(0);
Upload::save(0, 3);

काम करने का उदाहरण

हमें अपलोड कार्यक्षमता का परीक्षण करने के लिए अपने कर्मचारी नमूने में एक नया नियंत्रक, कंट्रोलर_अपलोड करें।

Step 1 - एक फ़ाइल बनाएँ, fuel/app/classes/controller/upload.php। अपलोड कंट्रोलर बनाएं।

<?php 
   class Controller_Upload extends Controller { 
   }

Step 2 - एक नया एक्शन get_upload बनाएं।

<?php  
   class Controller_Upload extends Controller { 
      public function get_index() { 
         return \View::forge("upload/index"); 
      } 
   }

Step 3 - बनाई गई कार्रवाई के लिए एक नया दृश्य बनाएं।

<!DOCTYPE html> 
<html> 
   <body> 
   
      <form action = "/upload/index" method = "post" enctype = "multipart/form-data"> 
         Select image to upload: 
         <input type = "file" name = "fileToUpload" id = "fileToUpload"> 
         <input type = "submit" value = "Upload Image" name = "submit"> 
      </form>  
      
   </body> 
</html>

Step 4 - अपलोड की गई फ़ाइल को संसाधित करने के लिए एक नया एक्शन पोस्ट_एक्शन बनाएं।

<?php  
   class Controller_Upload extends Controller { 
      public function get_index() { 
         return \View::forge("upload/index"); 
      }  
      public function post_index(){ 
         $config = array( 
            'path' => DOCROOT.'files', 
            'randomize' => true, 
            'ext_whitelist' => array('img', 'jpg', 'jpeg', 'gif', 'png'), 
         );  
         Upload::process($config);  
         // if there are any valid files 
         
         if (Upload::is_valid()) { 
            Upload::save(); 
            echo "success"; 
         } else { 
            // and process any errors 
            foreach (Upload::get_errors() as $file) { 
               echo var_dump($file); 
            } 
         } 
      } 
   }

अंत में, url का अनुरोध करके एप्लिकेशन चलाएँ, http://localhost:8080/upload/index और फ़ाइल अपलोड करने का प्रयास करें।

परिणाम