| |||||||
| المدوّنات | البحث | مشاركات اليوم | اجعل كافة المشاركات مقروءة |
|
| | LinkBack | أدوات الموضوع |
| |||||
| حماية صفحة مثل السي بنل هناك طريقة تضع كود باعلى الصفحة ويظهر لك مربع حوار يطلب اسم المسخدم وكلمة السر .. عند طلب الصفحة .. كود PHP:
__________________ اللهم صل علي سيدنا محمد وعلي آل سيدنا محمد وصحبه وسلم | |||||
|
| |||||
|
مشكور اخي ابوطارق جزاك الله كل الخير لكن سوألي هل افضل وأامن من طريقة session او cookies ؟؟؟؟؟؟؟؟؟؟؟؟؟؟ هل المقصود // كود الصفحة الباقية .. (( محتويات الصفحة )) التي نريدها ان تظهر الا لمن يملك اسم المستخدم وكلمة المرور واخيرا ياريت لو تشرح لنا طريقة حماية محتويات الصفحة بأستخدام session لاني عملت سكربت بسيط لوحة تحكم بسيطة لكني اريد ان احمي صفحة لوحة التحكم بأسم مستخدم وكلمة مرور وشكرا | |||||
|
| |||||
|
لماذا السيشن؟ السيشن Sessions هي من اهم المزايا التي تتمتع بها اي لغة برمجة، ونحتاجها دائماً عندما تظهر الحاجة لنقل بيانات بين صفحات السكريبت، ففي أي سكريبت عادي يتم فقدا، المتغيرات الخاصة بالصفحة عند الانتقال الى صفحة أخرى، وهذه تمثل مشكلة في بعض السكريبتات مثل "سلة التسوق" والتي تحتوي معلومات عن بضائع وخدمات قام المستخدم بشرائها، والتي يجب ان تحفظ خلال جولته في الموقع، من هنا تظهر الحاجة لاستخدام السيشن sessions. طريقة عمل السيشن لتلبية المتطلبات المشروحة في السطور السابقة، تقوم السيشن بتخزين بيانات عن الزائر (مثل: اسم المستخدم ومحتويات سلة التسوق) على السيرفر نفسه في مكان آمن بعيداً عن المتطفلين، ولكن هذه البيانات تعتبر مؤقتة فسرعان ما يتم حذفها بمجرد ترك الزائر للموقع، فاذا كنت تحتاج للاحتفاظ بها لمدة أطول يجب أن تقوم بنقلها الى قاعدة البيانات MySQL للاحتفاظ بها لفترات أطول. وتعمل السيشن عن طريق انشاء رقم تعريفي UID مميز لكل زائر للموقع بهذه الطريقة لا يمكن ان تختلط بيانات اثنين من الزوار أبداً. بدء السيشن الخطوة الأولى للتعامل مع السيشن هي بدءها، وعند بداية السيشن يجب أن تحرص على ان يكون كود البداية في أول الملف قبل أي كود HTML آخر، بمعنى آخر قبل طباعة أي شيء الى المتصفح. ويكون بدء السيشن باضافة الكود التالي الى بداية ملفك تماماً: مثال1: كود PHP: اضافة متغير الى السيشن لاضافة اي متغير الى السيشن استخدم المصفوفة SESSION_$ والتي ستحتاجها عند الاضافة والقراءة لمتغيرات السيشن، جدير بالذكر انه في الاصدارات القديمة من PHP كانت هناك طريقة أخرى لكن تم تحديثها الى هذه الطريقة حالياً: مثال2: كود PHP: استخدام الدالة isset عندما ترغب في قراءة قيمة متغير من السيشن فمن المهم ان تختبر اذا كان موجوداً أولاً، ويكون ذلك باستخدام الدالة isset مع تمرير اسم المتغير لها، لاحظ المثال التالي: مثال3: بفرض أننا أردنا انشاء عداد لعدد مرات مشاهدة صفحات السكريبت لكل مستخدم، فيمكننا ذلك عن طريق انشاء كود يقوم بالتأكد من وجود قيمة في العداد عن طريق الدالة isset فاذا كان له قيمة يضيف عليه 1 مشاهدة، واذا لم يكن له قيمة فيعطيه القيمة 1 وهي أول مشاهدة. لاحظ الكود التالي: كود PHP: 1- الا يكون هناك قيمة للمتغير views في المصفوفة SESSION_$، وهذا معناه ان هذه اول زيارة للزائر، وهنا سيتم تنفيذ الكود في السطر رقم 9 وهو باعطاء القيمة 1 للعداد views. 2- ان يكون هناك قيمة للمتغير المذكور، يعني هذه ليست أول زيارة وفي هذه الحالة سيتم تنفيذ الكود في السطر رقم 5 وهو بزيادة المتغير views بمقدار 1 زيارة. انهاء السيشن بالرغم من أن السيشن يتم انهائها أوتوماتيكياً بمجرد اغلاق المتصفح، ولكن هناك بعض الحالات التي يجب أن تنهي السيشن بنفسك وتحذف ما فيها من متغيرات. تخيل انك تمتلك موقع لبيع البضائع وقام زائر باتمام الشراء منك فيجب عليك ان تفرغ سلة التسوق الخاصة به، كالتالي: كود PHP: كما يمكنك ايضاً انهاء السيشن (تدميرها) بكل ما تحتويه من متغيرات كالتالي: كود PHP: وإلى الدرس التالي بإذن الله....
__________________ اللهم صل علي سيدنا محمد وعلي آل سيدنا محمد وصحبه وسلم التعديل الأخير تم بواسطة : ابوطارق بتاريخ 17-06-2008 الساعة 05:58 PM. سبب آخر: النسيان | |||||
|
| |||||
|
كود رائع انا استخدم الكود التالي وهو يعمل بكفاءة كود: <?php
if (!isset($_SERVER['PHP_AUTH_USER'])) {
header("WWW-Authenticate: Basic realm=\"Private Area\"");
header("HTTP/1.0 401 Unauthorized");
print "Sorry - you need valid credentials to be granted access!\n";
exit;
} else {
if (($_SERVER['PHP_AUTH_USER'] == 'paul') && ($_SERVER['PHP_AUTH_PW'] == 'hudson')) {
print "Welcome to the private area!";
} else {
header("WWW-Authenticate: Basic realm=\"Private Area\"");
header("HTTP/1.0 401 Unauthorized");
print "Sorry - you need valid credentials to be granted access!\n";
exit;
}
}
?> | |||||
|
| |||||
|
يعطيك العافيه اخوي ابو طارق بخصوص الاخ محمد .. وبعد إذن الأخ ابو طارق تفضل اخوي .. هذا شرح اخر لحماية لوحة التحكم من خلال السيشن PHPvillage قرية بي اتش بي لكن مع مراعاة ان الدرس قديم شوي .. اي ان هناك فرق في بعض الدوال مثل سوف تجد كود PHP: كود PHP: ------------------------------------ هناك ايضا : كود PHP: كود PHP: وايضا لتمدير الجلسة كاملة نستخدم : كود PHP: .. اسف للإطالة .. والشكر موصول للاخ ابو طارق ..
__________________ ----------------------------------------------------------- :: همـ المشاعر ــس :: عبد الله :: للتصميم و التطوير :: http://www.mr-sa.com ----------------------------------------------------------- | |||||
|
| |||||
|
أخي أبو طارق مع احترامي لك أعتقد أن الطريقة أصبحت قديمة و يوجد طرق كثيرة أفضل منها و هي أيضاً غير آمنة ... و الله أعلم
__________________ مدونة ديوبي ( مدونة تهتم بكل ما يتعلق ببرمجة الويب | |||||
|
![]() |
| |
| |
| أدوات الموضوع | |
| |
المواضيع المتشابهه | ||||
| الموضوع | كاتب الموضوع | المنتدى | مشاركات | آخر مشاركة |
| تعريب القالب X3 في السي بنل 11 مجانا وبدون اي برامج اضافية | محمد الشناق | قسم تبادل خبرات الاستضافة | 10 | 14-01-2008 12:14 AM |
| السي بنل .. يرفض حماية المجلدات | *المبدع* | تطوير الويب | 7 | 21-06-2007 12:39 PM |
| سؤال في السي بنل | سورية | تطوير الويب | 0 | 07-06-2006 01:10 PM |
| طريقة حماية صفحة لوحة تحكم اي سكربتات بطريقه سهله | الشبري | تطوير الويب | 7 | 30-08-2004 07:03 PM |
| في سؤال بخصوص السي بنل | darna | قسم تبادل خبرات الاستضافة | 2 | 05-03-2003 06:45 AM |