PHP - Hata ve Özel Durum İşleme
Hata işleme, programınız tarafından oluşturulan hataları yakalama ve ardından uygun eylemi gerçekleştirme sürecidir. Hataları düzgün bir şekilde ele alırsanız, öngörülemeyen birçok sonuca yol açabilir.
PHP'de bir hataları işlemek çok basittir.
Die () işlevini kullanma
PHP programınızı yazarken, devam etmeden önce olası tüm hata durumlarını kontrol etmeli ve gerektiğinde uygun önlemi almalısınız.
Sahip olmadan aşağıdaki örneği deneyin /tmp/test.xt dosya ve bu dosya ile.
<?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.
?>
Bu şekilde verimli bir kod yazabilirsiniz. Yukarıdaki tekniği kullanarak, hata verdiğinde programınızı durdurabilir ve daha anlamlı ve kullanıcı dostu bir mesaj görüntüleyebilirsiniz.
Özel Hata İşleme İşlevini Tanımlama
Herhangi bir hatayı ele almak için kendi fonksiyonunuzu yazabilirsiniz. PHP, hata işleme işlevini tanımlamak için size bir çerçeve sağlar.
Bu işlev en az iki parametreyi (hata seviyesi ve hata mesajı) işleyebilmelidir, ancak en fazla beş parametre (isteğe bağlı olarak: dosya, satır numarası ve hata içeriği) kabul edebilir -
Sözdizimi
error_function(error_level,error_message, error_file,error_line,error_context);
Sr.No | Parametre ve Açıklama |
---|---|
1 | error_level Gerekli - Kullanıcı tanımlı hata için hata raporu seviyesini belirtir. Bir değer numarası olmalıdır. |
2 | error_message Gerekli - Kullanıcı tanımlı hata için hata mesajını belirtir |
3 | error_file İsteğe bağlı - Hatanın oluştuğu dosya adını belirtir |
4 | error_line İsteğe bağlı - Hatanın oluştuğu satır numarasını belirtir |
5 | error_context İsteğe bağlı - Hata oluştuğunda kullanılan her değişkeni ve bunların değerlerini içeren bir dizi belirtir |
Olası Hata seviyeleri
Bu hata raporu seviyeleri, kullanıcı tanımlı hata işleyicinin kullanılabileceği farklı hata türleridir. Bu değerler cab kullanılarak kombinasyon halinde kullanılır| Şebeke
Sr.No | Sabit ve Açıklama | Değer |
---|---|---|
1 | .E_ERROR Önemli çalışma zamanı hataları. Komut dosyasının yürütülmesi durduruldu |
1 |
2 | E_WARNING Önemli olmayan çalışma zamanı hataları. Komut dosyasının yürütülmesi durdurulmadı |
2 |
3 | E_PARSE Derleme zamanı ayrıştırma hataları. Ayrıştırma hataları yalnızca ayrıştırıcı tarafından oluşturulmalıdır. |
4 |
4 | E_NOTICE Çalışma zamanı bildirimleri. Komut dosyası, hata olabilecek bir şey buldu, ancak bir komut dosyasını normal şekilde çalıştırırken de meydana gelebilecek |
8 |
5 | E_CORE_ERROR PHP'nin ilk başlangıcı sırasında meydana gelen ölümcül hatalar. |
16 |
6 | E_CORE_WARNING Önemli olmayan çalışma zamanı hataları. Bu, PHP'nin ilk başlangıcı sırasında meydana gelir. |
32 |
7 | E_USER_ERROR Kullanıcı tarafından oluşturulan önemli hata. Bu, programcı tarafından PHP işlevi trigger_error () kullanılarak ayarlanan bir E_ERROR gibidir. |
256 |
8 | E_USER_WARNING Kullanıcı tarafından oluşturulan önemli olmayan uyarı. Bu, programcı tarafından PHP işlevi trigger_error () kullanılarak ayarlanan bir E_WARNING gibidir. |
512 |
9 | E_USER_NOTICE Kullanıcı tarafından oluşturulan bildirim. Bu, programcı tarafından PHP işlevi trigger_error () kullanılarak ayarlanan bir E_NOTICE gibidir. |
1024 |
10 | E_STRICT Çalışma zamanı bildirimleri. PHP'nin kodunuzda en iyi birlikte çalışabilirliği ve kodunuzun ileriye dönük uyumluluğunu sağlayacak değişiklikler önermesini sağlayın. |
2048 |
11 | E_RECOVERABLE_ERROR Yakalanabilir ölümcül hata. Bu bir E_ERROR gibidir, ancak kullanıcı tanımlı bir tutamaç tarafından yakalanabilir (ayrıca bakınız set_error_handler ()) |
4096 |
12 | E_ALL E_STRICT seviyesi hariç tüm hatalar ve uyarılar (E_STRICT, PHP 6.0'dan itibaren E_ALL'un bir parçası olacaktır) |
8191 |
Yukarıdaki hata düzeyinin tümü, düzey cab'ın yukarıdaki tabloda tanımlanan değerlerden herhangi biri olduğu aşağıdaki PHP yerleşik kitaplık işlevi kullanılarak ayarlanabilir.
int error_reporting ( [int $level] )
Bir hata işleme işlevi oluşturmanın yolu aşağıdadır -
<?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();
}
?>
Özel hata işleyicinizi tanımladıktan sonra, PHP yerleşik kitaplığını kullanarak ayarlamanız gerekir set_error_handlerişlevi. Şimdi var olmayan bir işlevi çağırarak örneğimizi inceleyelim.
<?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();
?>
İstisnaların İşlenmesi
PHP 5, diğer programlama dillerindekine benzer bir istisna modeline sahiptir. İstisnalar önemlidir ve hata işleme üzerinde daha iyi bir kontrol sağlar.
İstisnalarla ilgili yeni anahtar kelimeyi açıklayalım.
Try- İstisna kullanan bir işlev "dene" bloğunda olmalıdır. İstisna tetiklenmezse, kod normal şekilde devam edecektir. Ancak istisna tetiklenirse, bir istisna "atılır".
Throw- Bu, bir istisnayı nasıl tetiklediğin. Her "atış" en az bir "tutuş" a sahip olmalıdır.
Catch - Bir "yakalama" bloğu, bir istisnayı alır ve istisna bilgilerini içeren bir nesne oluşturur.
Bir istisna atıldığında, ifadeyi izleyen kod çalıştırılmaz ve PHP ilk eşleşen catch bloğunu bulmaya çalışır. Bir istisna yakalanmazsa, "Yakalanmamış İstisna ..." ile birlikte bir PHP Önemli Hatası verilecektir.
PHP içinde bir istisna atılabilir ve yakalanabilir ("yakalanabilir"). Kod bir deneme bloğu içinde olabilir.
Her denemede en az bir karşılık gelen catch bloğu olmalıdır. Farklı istisna sınıflarını yakalamak için birden fazla yakalama bloğu kullanılabilir.
Bir catch bloğu içinde istisnalar atılabilir (veya yeniden fırlatılabilir).
Misal
Aşağıda kod parçası verilmiştir, bu kodu kopyalayıp bir dosyaya yapıştırın ve sonucu doğrulayın.
<?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';
?>
Yukarıdaki örnekte hata mesajı almak için $ e-> getMessage fonksiyonu kullanılmıştır. Kullanılabilecek aşağıdaki işlevler vardır:Exception sınıf.
getMessage() - istisna mesajı
getCode() - istisna kodu
getFile() - kaynak dosya adı
getLine() - kaynak hattı
getTrace() - backtrace'in n dizisi ()
getTraceAsString() - biçimlendirilmiş izleme dizisi
Özel İstisna İşleyici Oluşturma
Kendi özel istisna işleyicinizi tanımlayabilirsiniz. Kullanıcı tanımlı bir istisna işleyici işlevi ayarlamak için aşağıdaki işlevi kullanın.
string set_exception_handler ( callback $exception_handler )
Buraya exception_handleryakalanmamış bir istisna meydana geldiğinde çağrılacak işlevin adıdır. Bu işlev set_exception_handler () çağrılmadan önce tanımlanmalıdır.
Misal
<?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 Hata İşleme İşlevleri'ndeki tüm hata işleme işlevlerini kontrol edin