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