ड्रुपल - त्रुटि से निपटने
इस अध्याय में, हम Drupal साइट पर त्रुटि संदेशों के प्रबंधन के लिए Drupal त्रुटि से निपटने के बारे में अध्ययन करेंगे।
त्रुटि हैंडलिंग त्रुटियों के लिए प्रस्तावों का पता लगाने और खोजने की एक प्रक्रिया है। यह प्रोग्रामिंग एप्लिकेशन एरर या कम्युनिकेबल एरर हो सकता है।
निम्न चरण बताते हैं कि द्रुप में त्रुटि संदेशों को कैसे प्रबंधित किया जाए -
Step 1 - पर जाएं Configuration और क्लिक करें Logging and errors।
Step 2 - Logging and errors पृष्ठ को निम्न स्क्रीन में दिखाए अनुसार प्रदर्शित किया जाएगा।
निम्नलिखित क्षेत्रों का विवरण निम्नलिखित है जैसा कि पूर्ववर्ती स्क्रीन में देखा गया है -
Error messages to display - यह ड्रुपल साइट पर प्रदर्शित होने वाले त्रुटि संदेशों को निर्दिष्ट करता है।
None - यह विकल्प किसी भी त्रुटि संदेश को प्रदर्शित नहीं करता है।
Errors and warnings - यह विकल्प केवल त्रुटियों और चेतावनियों से संबंधित संदेश प्रदर्शित करता है।
All messages - यह विकल्प साइट पर प्रदर्शित किए जाने वाले सभी प्रकार के त्रुटि संदेशों जैसे त्रुटियों, चेतावनियों आदि को निर्दिष्ट करता है।
Database log messages to keep - यह डेटाबेस लॉग में रखे जाने वाले संदेशों की अधिकतम संख्या को इंगित करता है।
Drupal का उपयोग करता है _drupal_exception_handler ($exception)साइट पर त्रुटियों को संभालने के लिए कार्य करता है। इन त्रुटियों को एक कोशिश / पकड़ ब्लॉक में संलग्न नहीं किया जाएगा। जब स्क्रिप्ट एक अपवाद हैंडलर से बाहर निकलता है तो स्क्रिप्ट कार्य निष्पादित नहीं करेगी।
के लिए कोड _drupal_exception_handler इस प्रकार है -
function _drupal_exception_handler($exception) {
require_once DRUPAL_ROOT . '/includes/errors.inc';
try {
// display the error message in the log and return the error messages to the user
_drupal_log_error(_drupal_decode_exception($exception), TRUE); } catch (Exception $excp2) {
// Another uncaught exception was thrown while handling the first one.
// If we are displaying errors, then do so with no possibility of
a further uncaught exception being thrown.
if (error_displayable()) {
print '<h1>Additional uncaught exception thrown while handling exception.</h1>';
print '<h2>Original</h2> <p>'. _drupal_render_exception_safe($exception).'</p>'; print '<h2>Additional</h2> <p>'. _drupal_render_exception_safe($excp2).'</p><hr/>';
}
}
}
फ़ंक्शन का उपयोग प्रत्येक Drupal अनुरोध पर किया जाना चाहिए। यह फ़ंक्शन फ़ाइल में लाइन 2328 पर मौजूद हैincludes/bootstrap.inc।
के लिए दो स्ट्रिंग संदर्भ हैं _drupal_exception_handler जैसे कि_drupal_bootstrap_configuration() में मौजूद है bootstrap.inc फ़ाइल और_drupal_get_last_callerत्रुटियाँ.inc फ़ाइल में मौजूद हैं। ये दोनों फाइलें इसमें मौजूद हैं‘includes’ फ़ोल्डर।