المساعد الشخصي الرقمي

عرض الإصدار الكامل : تخزين الصور في قاعدة البيانات من نوع Mysql


صقر شمر
03-16-2006, 03:08 PM
أولا : قاعدة بياناتك
عند تصميم قاعدة بياناتك عندما تصميم جداولك تاكد من ان يكون الحقل الذي ستخزن به الصورة من نوع Longtext

مثال : قاعدة البيانات هذه تخزن الصور فقط

CREATE TABLE `imagesdb` (
`ID` INT NOT NULL AUTO_INCREMENT ,
`photdata` LONGTEXT NOT NULL ,
PRIMARY KEY ( `ID` )
);



ثانيا : ملف البرنامج أو ملف php

هناك أكثر من فرضية أنك استقبلت الصورة عن طريق التحميل عن طريق المتصفح أوأنك ستسحب الصورة من مجلد مثلا
في كلتا الحالتين بعد استقبال الصورة نحتاج إلى تشفيرها
<?
// سنفرض أننا أخذ عنوان الصورة أو الصورة بعد تحميلها من المتصف مثلا في متغير اسم
// filename
$finalimage = chunk_split(base64_encode($filename));
$sql = "INSERT INTO imagesdb SET photo='$finalimage";
mysql_query($sql);
?>


فنستخدم الدالة base64_encode للتشفير و هي ترجع بيانات مشفرة بنظام base64 و بعد التشفير ستتحول الصورة إلى نص كبير الحجم سنحول النص الجديد إلى مقاطع صغيرة عن طريق Chunk_split و سنضيف الناتج إلى القاعدة



ثالثا : عرض الصورة من القاعدة
نستخرج الصورة من قاعدة البيانات و من ثم نستخدم الدالة base64_decode لفك التشفير و إعادة الصورة لوضعها الطبيعي
<?
while ($row = mysql_fetch_array($result)) {
$thenewimage= $row["photo"];
echo base64_decode($thenewimage);

}

?>








م
ن
ق
و
ل

منقول للفائده

des-mshaer
03-17-2006, 05:44 AM
مكثور الخير يابعدي ولا هنت

أمير الجزيره
03-17-2006, 02:27 PM
الله يجزاك الجنه..

لا عدمناك..

طلال الحافظ
03-19-2006, 06:41 PM
مشكوووور أخوي صقر

عز الله انك حر