लोड हो रहा है...

File Uploads

PHP में File Uploads एक महत्वपूर्ण फीचर है, जो उपयोगकर्ताओं को अपने लोकल सिस्टम से सर्वर पर फाइलें अपलोड करने की अनुमति देता है। यह फीचर विशेष रूप से कंटेंट मैनेजमेंट सिस्टम, ई-कॉमर्स प्लेटफ़ॉर्म और सोशल मीडिया एप्लिकेशन में उपयोगी है, जहाँ उपयोगकर्ताओं को इमेज, डॉक्यूमेंट या अन्य फाइल टाइप अपलोड करने की आवश्यकता होती है। सुरक्षित और कुशल फ़ाइल अपलोड लागू करना अत्यंत महत्वपूर्ण है, ताकि एप्लिकेशन की इंटेग्रिटी बनी रहे और अनधिकृत फ़ाइल एक्सेस जैसी सुरक्षा समस्याएँ न उत्पन्न हों।
PHP में फाइल अपलोड आमतौर पर HTML फ़ॉर्म के माध्यम से किया जाता है और $_FILES सुपरग्लोबल का उपयोग करके फ़ाइल की जानकारी प्राप्त की जाती है। इसमें फ़ाइल का नाम, प्रकार, आकार और अस्थायी स्थान जैसी जानकारी शामिल होती है। File Uploads के प्रैक्टिकल कार्यान्वयन के लिए PHP की बेसिक और एडवांस्ड अवधारणाओं जैसे सिंटैक्स, डेटा स्ट्रक्चर, एल्गोरिदम और ऑब्जेक्ट ओरिएंटेड प्रिंसिपल्स का ज्ञान होना आवश्यक है।
इस ट्यूटोरियल में पाठक सीखेंगे कि PHP में फाइल अपलोड को सुरक्षित और परफॉर्मेंट तरीके से कैसे लागू किया जाए। इसमें फ़ाइल प्रकार और आकार की वेलिडेशन, त्रुटि प्रबंधन, अपलोड डायरेक्टरी का संगठन, और वास्तविक सॉफ़्टवेयर आर्किटेक्चर में इनका इंटीग्रेशन शामिल है। अंत में, उपयोगकर्ता PHP प्रोजेक्ट्स में File Uploads को प्रोफेशनली हैंडल करना सीखेंगे और PHP best practices को ध्यान में रखेंगे।

मूल उदाहरण

php
PHP Code
<?php
if ($_SERVER['REQUEST_METHOD'] === 'POST') {
if (isset($_FILES['file']) && $_FILES['file']['error'] === UPLOAD_ERR_OK) {
$uploadDir = __DIR__ . '/uploads/';
$uploadedFile = $uploadDir . basename($_FILES['file']['name']);

if ($_FILES['file']['size'] > 5 * 1024 * 1024) {
echo "फ़ाइल बहुत बड़ी है।";
exit;
}

$fileType = mime_content_type($_FILES['file']['tmp_name']);
if (!in_array($fileType, ['image/jpeg', 'image/png', 'image/gif'])) {
echo "असमर्थित फ़ाइल प्रकार।";
exit;
}

if (move_uploaded_file($_FILES['file']['tmp_name'], $uploadedFile)) {
echo "फ़ाइल सफलतापूर्वक अपलोड हुई।";
} else {
echo "फ़ाइल अपलोड विफल।";
}
} else {
echo "कोई फ़ाइल चयनित नहीं है।";
}
}
?>

<form method="post" enctype="multipart/form-data">
फ़ाइल चुनें: <input type="file" name="file">
<input type="submit" value="अपलोड करें">
</form>

इस उदाहरण में, सबसे पहले यह जाँचा जाता है कि रिक्वेस्ट POST विधि से आई है या नहीं। इसके बाद $_FILES सुपरग्लोबल का उपयोग करके फ़ाइल की मौजूदगी और किसी भी त्रुटि की जांच की जाती है। अपलोड डायरेक्टरी को सेट किया जाता है और basename का उपयोग करके फ़ाइल नाम सुरक्षित रखा जाता है, जिससे डायरेक्टरी ट्रैवर्सल हमले से सुरक्षा मिलती है।
फ़ाइल का आकार चेक करना और MIME प्रकार की जांच करना सुरक्षित फ़ाइल अपलोड सुनिश्चित करता है। move_uploaded_file फ़ाइल को अस्थायी स्थान से स्थायी अपलोड डायरेक्टरी में सुरक्षित रूप से ले जाता है। यह उदाहरण फ़ाइल अपलोड का पूरा वर्कफ़्लो दिखाता है और PHP में arrays, conditions, और basic security practices का अभ्यास कराता है।

व्यावहारिक उदाहरण

php
PHP Code
<?php
class FileUploader {
private string $uploadDir;
private array $allowedTypes;
private int $maxSize;

public function __construct(string $dir, array $types, int $sizeMB) {
$this->uploadDir = $dir;
$this->allowedTypes = $types;
$this->maxSize = $sizeMB * 1024 * 1024;
if (!is_dir($dir)) {
mkdir($dir, 0755, true);
}
}

public function upload(array $file): bool {
if ($file['error'] !== UPLOAD_ERR_OK) {
throw new RuntimeException('फ़ाइल अपलोड में त्रुटि।');
}

if ($file['size'] > $this->maxSize) {
throw new RuntimeException('फ़ाइल बहुत बड़ी है।');
}

$fileType = mime_content_type($file['tmp_name']);
if (!in_array($fileType, $this->allowedTypes)) {
throw new RuntimeException('असमर्थित फ़ाइल प्रकार।');
}

$destination = $this->uploadDir . basename($file['name']);
if (!move_uploaded_file($file['tmp_name'], $destination)) {
throw new RuntimeException('फ़ाइल को स्थानांतरित नहीं किया जा सका।');
}
return true;
}
}

try {
$uploader = new FileUploader(__DIR__ . '/uploads/', ['image/jpeg','image/png'], 5);
if ($_SERVER['REQUEST_METHOD'] === 'POST') {
$uploader->upload($_FILES['file']);
echo "फ़ाइल OOP के साथ सफलतापूर्वक अपलोड हुई।";
}
} catch (RuntimeException $e) {
echo "त्रुटि: " . $e->getMessage();
}
?>

<form method="post" enctype="multipart/form-data">
फ़ाइल चुनें: <input type="file" name="file">
<input type="submit" value="अपलोड करें">
</form>

यह व्यावहारिक उदाहरण FileUploader क्लास के माध्यम से ऑब्जेक्ट ओरिएंटेड प्रिंसिपल्स को दिखाता है। Constructor अपलोड डायरेक्टरी, अनुमत MIME प्रकार और अधिकतम आकार सेट करता है और आवश्यकतानुसार डायरेक्टरी बनाता है। upload मेथड RuntimeException का उपयोग करता है, जिससे त्रुटि प्रबंधन और मुख्य लॉजिक अलग रहता है।
इसमें फ़ाइल प्रकार और आकार की जाँच, और move_uploaded_file के उपयोग से सुरक्षित फ़ाइल अपलोड सुनिश्चित होता है। यह OOP समाधान स्केलेबल, मेंटेनबल और PHP best practices के अनुरूप है।

Performance के लिए upload_max_filesize और post_max_size सेट करें, डायरेक्टरी dynamically बनाएं और permissions सही रखें। Security के लिए executable फ़ाइलों को ब्लॉक करें, MIME type और extension को validate करें और अपलोड पथ सीमित करें। इन practices का पालन करने से File Uploads सुरक्षित, performant और maintainable रहते हैं।

📊 संदर्भ तालिका

PHP Element/Concept Description Usage Example
$_FILES उपयोगकर्ता द्वारा अपलोड की गई फ़ाइलों की जानकारी $_FILES['file']['name']
move_uploaded_file अस्थायी फ़ाइल को सुरक्षित स्थान पर स्थानांतरित करना move_uploaded_file($_FILES['file']['tmp_name'], $destination)
mime_content_type फ़ाइल का MIME type पता करना $type = mime_content_type($_FILES['file']['tmp_name']);
UPLOAD_ERR_OK सफल अपलोड के लिए कॉन्स्टेंट if ($_FILES['file']['error'] === UPLOAD_ERR_OK)
mkdir अपलोड डायरेक्टरी बनाना mkdir($uploadDir, 0755, true);
RuntimeException फ़ाइल अपलोड त्रुटियों के लिए Exception handling throw new RuntimeException('Upload failed');

🧠 अपने ज्ञान की परीक्षा करें

शुरू करने के लिए तैयार

अपने ज्ञान की परीक्षा करें

इस इंटरैक्टिव क्विज़ के साथ अपनी चुनौती लें और देखें कि आप विषय को कितनी अच्छी तरह समझते हैं

3
प्रश्न
🎯
70%
पास करने के लिए
♾️
समय
🔄
प्रयास

📝 निर्देश

  • हर प्रश्न को ध्यान से पढ़ें
  • हर प्रश्न के लिए सबसे अच्छा उत्तर चुनें
  • आप जितनी बार चाहें क्विज़ दोबारा दे सकते हैं
  • आपकी प्रगति शीर्ष पर दिखाई जाएगी