PHP - त्रुटि और अपवाद हैंडलिंग

त्रुटि हैंडलिंग आपके प्रोग्राम द्वारा उठाए गए त्रुटियों को पकड़ने और फिर उचित कार्रवाई करने की प्रक्रिया है। यदि आप त्रुटियों को ठीक से संभाल लेंगे तो इससे कई अप्रत्याशित परिणाम हो सकते हैं।

PHP में त्रुटियों को संभालने के लिए यह बहुत सरल है।

डाई () फ़ंक्शन का उपयोग करना

अपने PHP प्रोग्राम को लिखते समय आपको आगे बढ़ने से पहले सभी संभावित त्रुटि स्थिति की जांच करनी चाहिए और आवश्यकता पड़ने पर उचित कार्रवाई करनी चाहिए।

उदाहरण के बिना होने का प्रयास करें /tmp/test.xt फ़ाइल और इस फ़ाइल के साथ।

<?php
   if(!file_exists("/tmp/test.txt")) {
      die("File not found");
   }else {
      $file = fopen("/tmp/test.txt","r");
      print "Opend file sucessfully";
   }
   // Test of the code here.
?>

इस तरह आप एक कुशल कोड लिख सकते हैं। उपरोक्त तकनीक का उपयोग करके आप अपने प्रोग्राम को बंद कर सकते हैं जब भी यह गलत होता है और अधिक सार्थक और उपयोगकर्ता के अनुकूल संदेश प्रदर्शित करता है।

कस्टम त्रुटि हैंडलिंग फ़ंक्शन को परिभाषित करना

आप किसी भी त्रुटि को संभालने के लिए अपना स्वयं का फ़ंक्शन लिख सकते हैं। PHP आपको एरर हैंडलिंग फंक्शन को परिभाषित करने के लिए एक फ्रेमवर्क प्रदान करता है।

यह फ़ंक्शन न्यूनतम दो मापदंडों (त्रुटि स्तर और त्रुटि संदेश) को संभालने में सक्षम होना चाहिए, लेकिन अधिकतम पांच मापदंडों (वैकल्पिक रूप से: फ़ाइल, लाइन-नंबर और त्रुटि संदर्भ) को स्वीकार कर सकता है -

वाक्य - विन्यास

error_function(error_level,error_message, error_file,error_line,error_context);

अनु क्रमांक पैरामीटर और विवरण
1

error_level

आवश्यक - उपयोगकर्ता द्वारा परिभाषित त्रुटि के लिए त्रुटि रिपोर्ट स्तर निर्दिष्ट करता है। मान संख्या होनी चाहिए।

2

error_message

आवश्यक - उपयोगकर्ता द्वारा परिभाषित त्रुटि के लिए त्रुटि संदेश निर्दिष्ट करता है

3

error_file

वैकल्पिक - वह फ़ाइल नाम निर्दिष्ट करता है जिसमें त्रुटि हुई

4

error_line

वैकल्पिक - उस पंक्ति संख्या को निर्दिष्ट करता है जिसमें त्रुटि हुई

5

error_context

वैकल्पिक - एक चर निर्दिष्ट करता है जिसमें त्रुटि होने पर हर चर और उनके मूल्यों का उपयोग होता है

संभावित त्रुटि स्तर

ये त्रुटि रिपोर्ट स्तर उपयोगकर्ता द्वारा परिभाषित त्रुटि हैंडलर के लिए उपयोग की जा सकने वाली त्रुटि के विभिन्न प्रकार हैं। इन मूल्यों का उपयोग करते हुए संयोजन में प्रयुक्त टैक्सी| ऑपरेटर

अनु क्रमांक लगातार और विवरण मूल्य
1

.E_ERROR

घातक रन-टाइम त्रुटियाँ। स्क्रिप्ट का निष्पादन रोक दिया गया है

1
2

E_WARNING

गैर-घातक रन-टाइम त्रुटियाँ। स्क्रिप्ट का निष्पादन रुक नहीं रहा है

2
3

E_PARSE

संकलन-समय पार्स त्रुटियां। पार्स त्रुटियों को केवल पार्सर द्वारा उत्पन्न किया जाना चाहिए।

4
4

E_NOTICE

रन-टाइम नोटिस। स्क्रिप्ट में कुछ ऐसा पाया गया जो एक त्रुटि हो सकती है, लेकिन सामान्य रूप से स्क्रिप्ट चलाने पर भी हो सकती है

8
5

E_CORE_ERROR

PHP के शुरुआती स्टार्ट-अप के दौरान होने वाली घातक त्रुटियां।

16
6

E_CORE_WARNING

गैर-घातक रन-टाइम त्रुटियाँ। यह PHP के शुरुआती स्टार्ट-अप के दौरान होता है।

32
7

E_USER_ERROR

घातक उपयोगकर्ता-जनित त्रुटि। यह एक E_ERROR है जो प्रोग्रामर द्वारा PHP फंक्शन ट्रिगर_रोर () का उपयोग करके सेट किया गया है

256
8

E_USER_WARNING

गैर-घातक उपयोगकर्ता-जनरेट की गई चेतावनी। यह प्रोग्रामर द्वारा PHP फंक्शन ट्रिगर_रोर () का उपयोग करके E_WARNING सेट की तरह है।

512
9

E_USER_NOTICE

उपयोगकर्ता-जनित सूचना। यह प्रोग्रामर द्वारा PHP फंक्शन ट्रिगर_रोर () का उपयोग करके निर्धारित E_NOTICE की तरह है

1024
10

E_STRICT

रन-टाइम नोटिस। PHP को अपने कोड में परिवर्तन करने में सक्षम बनाने के लिए सक्षम करें जो आपके कोड के सर्वोत्तम अंतर और आगे संगतता सुनिश्चित करेगा।

2048
1 1

E_RECOVERABLE_ERROR

घातक त्रुटि। यह एक E_ERROR की तरह है लेकिन उपयोगकर्ता द्वारा परिभाषित हैंडल द्वारा पकड़ा जा सकता है (यह भी देखें set_error_handler ())

4096
12

E_ALL

सभी त्रुटियाँ और चेतावनियाँ, सिवाय E_STRICT के (E_STRICT PHP 6.0 के रूप में E_ALL का हिस्सा होंगी)

8191

उपरोक्त सभी त्रुटि स्तर PHP अंतर्निहित लाइब्रेरी फ़ंक्शन का उपयोग करके सेट किया जा सकता है, जहां लेवल कैब उपरोक्त तालिका में परिभाषित किसी भी मूल्य का हो सकता है।

int error_reporting ( [int $level] )

निम्नलिखित तरीके से आप एक त्रुटि हैंडलिंग फ़ंक्शन बना सकते हैं -

<?php
   function handleError($errno, $errstr,$error_file,$error_line) {
      echo "<b>Error:</b> [$errno] $errstr - $error_file:$error_line";
      echo "<br />";
      echo "Terminating PHP Script";
      
      die();
   }
?>

एक बार जब आप अपने कस्टम त्रुटि हैंडलर को परिभाषित करते हैं, तो आपको इसे PHP निर्मित लाइब्रेरी का उपयोग करके सेट करना होगा set_error_handlerसमारोह। अब एक फ़ंक्शन को कॉल करके हमारे उदाहरण की जांच करें जो मौजूद नहीं है।

<?php
   error_reporting( E_ERROR );
   
   function handleError($errno, $errstr,$error_file,$error_line) {
      echo "<b>Error:</b> [$errno] $errstr - $error_file:$error_line";
      echo "<br />";
      echo "Terminating PHP Script";
      
      die();
   }
   
   //set error handler
   set_error_handler("handleError");
   
   //trigger error
   myFunction();
?>

अपवाद हैंडलिंग

PHP 5 में अन्य प्रोग्रामिंग भाषाओं के समान एक अपवाद मॉडल है। अपवाद महत्वपूर्ण हैं और त्रुटि से निपटने पर बेहतर नियंत्रण प्रदान करता है।

अपवादों से संबंधित नए कीवर्ड की व्याख्या करें।

  • Try- अपवाद का उपयोग करने वाला एक फ़ंक्शन "कोशिश" ब्लॉक में होना चाहिए। यदि अपवाद ट्रिगर नहीं करता है, तो कोड सामान्य रूप से जारी रहेगा। हालाँकि यदि अपवाद ट्रिगर होता है, तो एक अपवाद "फेंका गया" है।

  • Throw- यह है कि आप एक अपवाद को कैसे ट्रिगर करते हैं। प्रत्येक "थ्रो" में कम से कम एक "कैच" होना चाहिए।

  • Catch - एक "कैच" ब्लॉक एक अपवाद को पुनः प्राप्त करता है और एक वस्तु बनाता है जिसमें अपवाद जानकारी होती है।

जब एक अपवाद को फेंक दिया जाता है, तो कथन के बाद वाले कोड को निष्पादित नहीं किया जाएगा, और PHP पहले मिलान पकड़ने वाले ब्लॉक को खोजने का प्रयास करेगा। यदि अपवाद नहीं पकड़ा गया है, तो एक PHP घातक त्रुटि "बिना किसी अपवाद के जारी की जाएगी ...

  • PHP के भीतर एक अपवाद फेंका जा सकता है, और पकड़ा ("पकड़ा") जा सकता है। कोड एक कोशिश ब्लॉक में घिरा हो सकता है।

  • प्रत्येक प्रयास में कम से कम एक संगत कैच ब्लॉक होना चाहिए। अपवादों के विभिन्न वर्गों को पकड़ने के लिए एकाधिक कैच ब्लॉक का उपयोग किया जा सकता है।

  • अपवादों को कैच ब्लॉक के भीतर (या फिर से फेंक दिया) जा सकता है।

उदाहरण

निम्नलिखित कोड का टुकड़ा है, इस कोड को एक फ़ाइल में कॉपी और पेस्ट करें और परिणाम सत्यापित करें।

<?php
   try {
      $error = 'Always throw this error';
      throw new Exception($error);
      
      // Code following an exception is not executed.
      echo 'Never executed';
   }catch (Exception $e) {
      echo 'Caught exception: ',  $e->getMessage(), "\n";
   }
   
   // Continue execution
   echo 'Hello World';
?>

उपरोक्त उदाहरण में $ e-> getMessage फ़ंक्शन का उपयोग त्रुटि संदेश प्राप्त करने के लिए किया जाता है। निम्नलिखित कार्य हैं जिनका उपयोग किया जा सकता हैException कक्षा।

  • getMessage() - अपवाद का संदेश

  • getCode() - अपवाद का कोड

  • getFile() - स्रोत फ़ाइल नाम

  • getLine() - सोर्स लाइन

  • getTrace() - बैकट्रेस की एन सरणी ()

  • getTraceAsString() - ट्रेस की तैयार की गई स्ट्रिंग

कस्टम अपवाद हैंडलर बनाना

आप अपने स्वयं के कस्टम अपवाद हैंडलर को परिभाषित कर सकते हैं। उपयोगकर्ता-परिभाषित अपवाद हैंडलर फ़ंक्शन सेट करने के लिए निम्न फ़ंक्शन का उपयोग करें।

string set_exception_handler ( callback $exception_handler )

यहाँ exception_handlerफंक्शन का नाम है जिसे अनकैप्ड अपवाद होने पर कॉल किया जाता है। इस फ़ंक्शन को set_exception_handler () को कॉल करने से पहले परिभाषित किया जाना चाहिए।

उदाहरण

<?php
   function exception_handler($exception) {
      echo "Uncaught exception: " , $exception->getMessage(), "\n";
   }
	
   set_exception_handler('exception_handler');
   throw new Exception('Uncaught Exception');
   
   echo "Not Executed\n";
?>

PHP त्रुटि हैंडलिंग कार्यों में त्रुटि हैंडलिंग कार्यों का पूरा सेट देखें