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 त्रुटि हैंडलिंग कार्यों में त्रुटि हैंडलिंग कार्यों का पूरा सेट देखें