بسم الله الرحمن الرحيم
مقدمة
تسمح لك تقنية mod_rewrite والموجودة في برنامج Apache الشهير بتحويل زوار الموقع من رابط الى رابط آخر دون علمهم ودون تغيير الرابط في المتصفح، هذا يمكنك من تحويل الزائر من رابط الصفحة القديم الى الرابط الجديد مثلاً، كما تسمح لك بإعادة كتابة الروابط بالشكل الذي تريده ويسهل على الزائر وعلى محرك البحث أيضاً فهمها.
مثلاً، يمكنك استبدال رابط مثل:بهذا الرابط: والذي يسهل على الزائر فهمه ومعرفة محتواه..
بالاضافة الى المزايا السابقة لاستخدام تقنية mod_rewrite، فعدم استخدامها ينطوي على عدة عيوب منها:
1- سهولة معرفة لغة البرمجة المستخدمة في الموقع، وبالتالي إعطاء الفرصة للمخترقين والمخربين بمحاولة اختراق الموقع عن طريق حقن الاستعلامات في الرابط أو اي طريقة أخرى، بالاضافة الى ان التقنية المستخدمة وكيفية سير البرنامج ينبغي أن تظل سرية ومجوبة عن الزوار.
2- احتواء الرابط على المتغيرات والعلامة "&" والتي تعتبر غير مطابقة للمواصفات القياسية XHTML والتي ينبغي ان يتم معالجتها قبل ادراج الرابط في صفحات مواقع أخرى.
3- بعض محركات البحث لا تقبل على أرشفة الصفحات التي تحتوي روابطها على علامة ؟ وبالتالي يقل ترتيب الموقع في محركات البحث.
هنا تظهر أهمية استخدام التقنية mod_rewrite والتي بفضلها يمكننا تحويل هذا الرابط الغير محبوب سيء المنظر الى رابط بهذا الشكل:
هل لاحظت الفرق بين الرابطين؟ الرابط الثاني أسهل وقابل للحفظ أكثر كما انه معبر اكثر عن محتوى الصفحة وقابل للأرشفة من محركات البحث.
كيفية استخدام mod_rewrite
لكي تستخدم هذه التقنية يجب أولاً أن نشغل هذه الخاصية على السيرفر، ويتم ذلك عن طريق وضع الكود التالي في ملف htacces. في المجلد الرئيسي للموقع، حتى تعمل الخاصية في هذا المجلد والمجلدات المتفرعة منه، والكود هو كالتالي:
بعد اضافة هذا الكود وتشغيل الخاصية، ينبغي اخبار السيرفر بكيفية التصرف حيال الروابط، وذلك عن طريق تمرير التعليمات له عن طريق الأمر RewriteRule، ويستخدم هذا الأمر كالتالي:
حيث:
URL1 هو الرابط المراد مطابقته
و URL2 هو الرابط المراد توجيه الزائر له عند دخوله للرابط الأول
مثال:
قمت بتغيير اسم ملف قديم الى اسم جديد، كيف ستتصرف حيال الروابط الموجودة في المواقع الأخرى والتي تحتوي الإسم القديم للملف؟؟ وهل يعقل ان تخسر أرشفة محركات البحث لهذه الروابط القديمة؟
الحل:
يمكنك حل هذه المشكلة باستخدام mod_rewrite وتوجيه الزوار من الرابط القديم المعروف لديهم الى الرابط الجديد، كالتالي:
الكود السابق هو ابسط اكواد mod_rewrite، واليك تفصيله:
في السطر الأول قمنا بتشغيل الخاصية.
في السطر الثاني قمنا بتحويل الزائر من الملف old.html الى الملف new.html
لاحظ ما يلي:
العلامة ^ تستخدم دائماً للدلالة على بداية الرابط الأول
العلامة $ تستخدم دائماً للدلالة على نهاية الرابط الأول
العلامة . (النقطة) لها معنى خاص في التعابير المنتظمة، ويجب أن نخبر السيرفر بأن يعاملها كنقطة عادية لذلك سبقناها بالعلامة \
طيب بعد اضافة الكود و عند دخول الزائر للصفحة old.html سيتم توجيهه تلقائياً ودون علمه للصفحة new.html، ويبقى عنوان الصفحة في المتصفح مثل ما كان عليه old.html
ولكن ماذا لو أردنا ان يعرف الزائر أنه قد تم توجيهه لصفحة أخرى؟ ويتغير رابط الصفحة في المتصفح؟
علينا باستخدام هذا الكود بدلا من الأول:
حرف [R] بين القوسين المربعين يعني انه يتم فعلا التوجيه مع معرفة الزائر بذلك...
حتى الآن فالموضوع بسيط ومفهوم على ما أعتقد.. ولكن في اغلب الأحوال نحتاج الى بناء كود معقد، ففي الغالب لا نعرف اسم الملف الموجه ولا الموجه اليه، واذا عرفناهم فهم كثير ونريد ان نضع قاعدة عامة يتم التوجيه بناءاً عليها، أيضاً نود تمرير المتغيرات بطريقة GET ..
هنا تأتي الحاجة لاستخدام التاعبير المنتظمة REGULAR EXPRESSIONS
mod_rewrite والتعابير المنتظمة (Regular Expressions)
نصل الآن الى الجزء المهم، وهو المفيد فعلا والمستخدم بكثرة في هذه الخاصية، فهو مفيد وشيق بقدر ماهو معقد، لذا يلزم التركيز جيداً والانتباه في هذه الجزئية.
فيمكنك باستخدام التعابير المنتظمة اخبار السيرفر بان يقوم بتحويل أي رابط يطابق الصيغة التي تكتبها الى رابط آخر، واليك هذا الكود:
فيقوم هذا الكود بمطابقة أي رابط يبدأ بـ "products/" ويتبعها رقمين ثم العلامة "/"، فعلى سبيل المثال يعمل هذا الكود عند كتابة الرابط
http://www.site.com/products/29/
أو الرابط http://www.site.com/products/62/
ويوجهه الى الصفحة http://www.site.com/productInfo?prodId=29
أو http://www.site.com/productInfo?prodId=62 على التوالي.
واليك تفصيل الكود السابق:
بالنسبة للشطر الأول:
^ تدل على بداية الرابط
$ تدل على نهاية الرابط
[0-9] تعني اي رقم من 0 وحتى 9، وتكرارها مرتين تعني انه رقم مكون من عددين
() والأقواس تعني وضع مابينها في متغير يتم استخدامه فيما بعد في نفس السطر
أما الشطر الثاني
فهو الرابط الحقيقي الذي سيتم التوجيه له
والعلامة $1 تعني استخدام المتغير الموجود بين الأقواس () في الشطر الأول في هذا المكان..
إذاً فهكذا تعمل الأشياء...
طيب الكود في المثال السابق يوجه الزائر عند كتابة رابط مثل هذا: http://www.site.com/products/62/
طيب ماذا يحدث لو نسي الزائر كتابة علامة "/" في النهاية؟ الاجابة لن يتم التوجيه وسيحصل الزائر على صفحة خطأ 404
يمكننا معالجة ذلك عن طريق اجبار السيرفر باضافة العلامة "/" حتى ولو لم يضفها الزائر في نهاية الرابط، كالتالي:
لاحظ أننا استخدمنا [R] هنا لاظهار التغيير في المتصفح ولكي يعرف الزائر انه يتحتم عليه كتابة العلامة "/" في نهاية الرابط
ولكن ماذا لو زاد عدد المنتجات عندنا عن 99؟ ماذا لو اصبحوا 100 او 200 منتج؟
هل سنضطر لتكرار الكود [0-9] بعدد المنتجات المتوقعة؟
الاجابة طبعا لا فيمكنك استخدام الكود التالي للدلالة على أي عدد من الأرقام بعد [l]products/[/l]
فالعلامة + تعني او أكثر، يعني رقم واحد أو أكثر..
إلى هنا تكون قد وصلت الى قدر جيد جداً في تعلم هذه الخاصية...
طبعا ًمازال هناك الكثير والكثير يمكن عمله بالخاصية .. ولكن نكتفي بهذا القدر كبدايةً
للأمانة منقول من منتدى بى اتش بى
مقدمة
تسمح لك تقنية mod_rewrite والموجودة في برنامج Apache الشهير بتحويل زوار الموقع من رابط الى رابط آخر دون علمهم ودون تغيير الرابط في المتصفح، هذا يمكنك من تحويل الزائر من رابط الصفحة القديم الى الرابط الجديد مثلاً، كما تسمح لك بإعادة كتابة الروابط بالشكل الذي تريده ويسهل على الزائر وعلى محرك البحث أيضاً فهمها.
مثلاً، يمكنك استبدال رابط مثل:
كود :
http://www.site.com/showCategory.php?catId=34
كود :
http://www.site.com/category/34/
بالاضافة الى المزايا السابقة لاستخدام تقنية mod_rewrite، فعدم استخدامها ينطوي على عدة عيوب منها:
1- سهولة معرفة لغة البرمجة المستخدمة في الموقع، وبالتالي إعطاء الفرصة للمخترقين والمخربين بمحاولة اختراق الموقع عن طريق حقن الاستعلامات في الرابط أو اي طريقة أخرى، بالاضافة الى ان التقنية المستخدمة وكيفية سير البرنامج ينبغي أن تظل سرية ومجوبة عن الزوار.
2- احتواء الرابط على المتغيرات والعلامة "&" والتي تعتبر غير مطابقة للمواصفات القياسية XHTML والتي ينبغي ان يتم معالجتها قبل ادراج الرابط في صفحات مواقع أخرى.
3- بعض محركات البحث لا تقبل على أرشفة الصفحات التي تحتوي روابطها على علامة ؟ وبالتالي يقل ترتيب الموقع في محركات البحث.
هنا تظهر أهمية استخدام التقنية mod_rewrite والتي بفضلها يمكننا تحويل هذا الرابط الغير محبوب سيء المنظر الى رابط بهذا الشكل:
كود :
http://www.site.com/category/34/
كيفية استخدام mod_rewrite
لكي تستخدم هذه التقنية يجب أولاً أن نشغل هذه الخاصية على السيرفر، ويتم ذلك عن طريق وضع الكود التالي في ملف htacces. في المجلد الرئيسي للموقع، حتى تعمل الخاصية في هذا المجلد والمجلدات المتفرعة منه، والكود هو كالتالي:
كود :
RewriteEngine on
كود :
RewriteRule URL1 URL2
URL1 هو الرابط المراد مطابقته
و URL2 هو الرابط المراد توجيه الزائر له عند دخوله للرابط الأول
مثال:
قمت بتغيير اسم ملف قديم الى اسم جديد، كيف ستتصرف حيال الروابط الموجودة في المواقع الأخرى والتي تحتوي الإسم القديم للملف؟؟ وهل يعقل ان تخسر أرشفة محركات البحث لهذه الروابط القديمة؟
الحل:
يمكنك حل هذه المشكلة باستخدام mod_rewrite وتوجيه الزوار من الرابط القديم المعروف لديهم الى الرابط الجديد، كالتالي:
كود :
RewriteEngine on
RewriteRule ^old\.html$ new.html
الكود السابق هو ابسط اكواد mod_rewrite، واليك تفصيله:
في السطر الأول قمنا بتشغيل الخاصية.
في السطر الثاني قمنا بتحويل الزائر من الملف old.html الى الملف new.html
لاحظ ما يلي:
العلامة ^ تستخدم دائماً للدلالة على بداية الرابط الأول
العلامة $ تستخدم دائماً للدلالة على نهاية الرابط الأول
العلامة . (النقطة) لها معنى خاص في التعابير المنتظمة، ويجب أن نخبر السيرفر بأن يعاملها كنقطة عادية لذلك سبقناها بالعلامة \
طيب بعد اضافة الكود و عند دخول الزائر للصفحة old.html سيتم توجيهه تلقائياً ودون علمه للصفحة new.html، ويبقى عنوان الصفحة في المتصفح مثل ما كان عليه old.html
ولكن ماذا لو أردنا ان يعرف الزائر أنه قد تم توجيهه لصفحة أخرى؟ ويتغير رابط الصفحة في المتصفح؟
علينا باستخدام هذا الكود بدلا من الأول:
كود :
RewriteEngine on
RewriteRule ^old\.html$ new.html [R]
حرف [R] بين القوسين المربعين يعني انه يتم فعلا التوجيه مع معرفة الزائر بذلك...
حتى الآن فالموضوع بسيط ومفهوم على ما أعتقد.. ولكن في اغلب الأحوال نحتاج الى بناء كود معقد، ففي الغالب لا نعرف اسم الملف الموجه ولا الموجه اليه، واذا عرفناهم فهم كثير ونريد ان نضع قاعدة عامة يتم التوجيه بناءاً عليها، أيضاً نود تمرير المتغيرات بطريقة GET ..
هنا تأتي الحاجة لاستخدام التاعبير المنتظمة REGULAR EXPRESSIONS
mod_rewrite والتعابير المنتظمة (Regular Expressions)
نصل الآن الى الجزء المهم، وهو المفيد فعلا والمستخدم بكثرة في هذه الخاصية، فهو مفيد وشيق بقدر ماهو معقد، لذا يلزم التركيز جيداً والانتباه في هذه الجزئية.
فيمكنك باستخدام التعابير المنتظمة اخبار السيرفر بان يقوم بتحويل أي رابط يطابق الصيغة التي تكتبها الى رابط آخر، واليك هذا الكود:
كود :
RewriteRule ^products/([0-9][0-9])/$ /productInfo.php?prodId=$1
http://www.site.com/products/29/
أو الرابط http://www.site.com/products/62/
ويوجهه الى الصفحة http://www.site.com/productInfo?prodId=29
أو http://www.site.com/productInfo?prodId=62 على التوالي.
واليك تفصيل الكود السابق:
بالنسبة للشطر الأول:
كود :
^products/([0-9][0-9])/$
$ تدل على نهاية الرابط
[0-9] تعني اي رقم من 0 وحتى 9، وتكرارها مرتين تعني انه رقم مكون من عددين
() والأقواس تعني وضع مابينها في متغير يتم استخدامه فيما بعد في نفس السطر
أما الشطر الثاني
كود :
/productInfo.php?prodId=$1
والعلامة $1 تعني استخدام المتغير الموجود بين الأقواس () في الشطر الأول في هذا المكان..
إذاً فهكذا تعمل الأشياء...
طيب الكود في المثال السابق يوجه الزائر عند كتابة رابط مثل هذا: http://www.site.com/products/62/
طيب ماذا يحدث لو نسي الزائر كتابة علامة "/" في النهاية؟ الاجابة لن يتم التوجيه وسيحصل الزائر على صفحة خطأ 404
يمكننا معالجة ذلك عن طريق اجبار السيرفر باضافة العلامة "/" حتى ولو لم يضفها الزائر في نهاية الرابط، كالتالي:
كود :
RewriteRule ^products/([0-9][0-9])$ /products/$1/ [R]
RewriteRule ^products/([0-9][0-9])/$ /productInfo.php?prodId=$1
ولكن ماذا لو زاد عدد المنتجات عندنا عن 99؟ ماذا لو اصبحوا 100 او 200 منتج؟
هل سنضطر لتكرار الكود [0-9] بعدد المنتجات المتوقعة؟
الاجابة طبعا لا فيمكنك استخدام الكود التالي للدلالة على أي عدد من الأرقام بعد [l]products/[/l]
كود :
RewriteRule ^products/([0-9]+)/$ /productInfo.php?prodId=$1
إلى هنا تكون قد وصلت الى قدر جيد جداً في تعلم هذه الخاصية...
طبعا ًمازال هناك الكثير والكثير يمكن عمله بالخاصية .. ولكن نكتفي بهذا القدر كبدايةً
للأمانة منقول من منتدى بى اتش بى