ब्लॉब फ़ाइल के साथ काम करते समय यह सबसे आम समस्या है। आपके उदाहरण से, मैं देख सकता हूं कि आप "फाइल टाइप" को फाइलों के एक्सटेंशन के रूप में सहेज रहे हैं (यानी छवियों के लिए 'जेपीजी', पीडीएफ फाइलों के लिए 'पीडीएफ' आदि), आप अपलोड कर रहे हैं। लेकिन इसके बजाय आप फ़ाइल प्रकार को MIME सामग्री प्रकार के रूप में सहेज सकते हैं।
मान लीजिए यदि आप एक jpeg छवि अपलोड करते हैं - MIME प्रकार "fileType" में "छवि/jpeg" के रूप में संग्रहीत किया जाएगा। इसी तरह पीडीएफ के लिए इसे "एप्लिकेशन/पीडीएफ" के रूप में संग्रहीत किया जाएगा। मैंने डेटाबेस से ब्लॉब फ़ाइल डाउनलोड करने के लिए इस तरह कोड डिज़ाइन किया है। मैं यह मानने जा रहा हूं कि फ़ाइलें आपके द्वारा बनाई गई डेटाबेस तालिका में पहले ही अपलोड हो चुकी हैं।
डेटाबेस तालिका "अपलोड"
| फ़ाइल आईडी | फ़ाइल का नाम | फ़ाइल प्रकार | फ़ाइल आकार |फ़ाइलडेटा | उपयोगकर्ता आईडी |
डाउनलोड करें.php
<?php
$connection = mysqli_connect("localhost","root"," ",your_database)
or die('Database Connection Failed');
mysqli_set_charset($connection,'utf-8');
$id = 1;
// Use a prepared statement in production to avoid SQL injection;
// we can get away with this here because we're the only ones who
// are going to use this script.
$query = "SELECT * " ."FROM uploads WHERE userID = '$id'";
$result = mysqli_query($connection,$query)
or die('Error, query failed');
list($id, $file, $type, $size,$content) = mysqli_fetch_array($result);
header("Content-length: $size");
header("Content-type: $type");
header("Content-Disposition: attachment; filename=$file");
ob_clean();
flush();
echo $content;
mysqli_close($connection);
exit;
?>
आपको ब्लॉब-अपलोड का पूरा कोड यहां मिल सकता है ।