Hàm xử lý lỗi và log trong PHP



Đây là những hàm xử lý lỗi và xử lý các vấn đề về log trong PHP. Chúng cho phép bạn định nghĩa các qui tắc xử lý lỗi cho riêng bạn, cũng như chỉnh sửa cách lỗi đó có thể được log. Điều này cho phép bạn thay đổi và cải thiện việc báo cáo lỗi phù hợp với yêu cầu của bạn.

Sử dụng các hàm xử lý log này, bạn có thể gửi message một cách trực tiếp tới thiết bị khác, tới một Email, các các System log, … để bạn có thể log và giám sát các phần quan trọng của ứng dụng.

Cài đặt

Những hàm xử lý lỗi và xử lý log là một phần của PHP Core. Bạn không cần cài đặt gì thêm để sử dụng các hàm này.

Cấu hình Runtime

Chế độ vận hành của các hàm xử lý lỗi và xử lý log trong PHP phụ thuộc vào các cài đặt trong php.ini. Các cài đặt này được định nghĩa ở bảng sau:

Tên Mặc định Có thể thay đổi Changelog
error_reporting NULL PHP_INI_ALL
display_errors "1" PHP_INI_ALL
display_startup_errors "0" PHP_INI_ALL Có sẵn từ PHP 4.0.3.
log_errors "0" PHP_INI_ALL
log_errors_max_len "1024" PHP_INI_ALL Có sẵn từ PHP 4.3.0.
ignore_repeated_errors "0" PHP_INI_ALL Có sẵn từ PHP 4.3.0.
ignore_repeated_source "0" PHP_INI_ALL Có sẵn từ PHP 4.3.0.
report_memleaks "1" PHP_INI_ALL Có sẵn từ PHP 4.3.0.
track_errors "0" PHP_INI_ALL
html_errors "1" PHP_INI_ALL PHP_INI_SYSTEM trong PHP <= 4.2.3. Có sẵn từ PHP 4.0.2.
docref_root "" PHP_INI_ALL Có sẵn từ PHP 4.3.0.
docref_ext "" PHP_INI_ALL Có sẵn từ PHP 4.3.2.
error_prepend_string NULL PHP_INI_ALL
error_append_string NULL PHP_INI_ALL
error_log NULL PHP_INI_ALL
warn_plus_overloading NULL Tùy chọn này không còn có sẵn ở trong PHP 4.0.0

Hằng về Error và Logging trong PHP

Cột PHP chỉ phiên bản PHP sớm nhất hỗ trợ hằng đó.

Bạn có thể sử dụng bất kỳ hằng nào trong khi cấu hình php.ini file của bạn.

Giá trị Hằng Miêu tả PHP
1 E_ERROR Fatal run-time error. Đây là các lỗi nghiêm trọng, và việc thực thi của script bị ngừng lại
2 E_WARNING Non-fatal run-time error. Đây là các lỗi không nghiêm trọng, và việc thực thi của script không bị ngừng lại
4 E_PARSE Compile-time parse error. Lỗi về Parse trong khi biên dịch, và nên chỉ được tạo bởi Parser
8 E_NOTICE Run-time notice. Script tìm thấy cái gì đó có thể là một lỗi, nhưng cũng có thể xảy ra khi đang chạy một Script một cách bình thường
16 E_CORE_ERROR Fatal error tại quá trình khởi động PHP. Lỗi này khá giống một E_ERROR trong PHP Core 4
32 E_CORE_WARNING Non-fatal error tại quá trình khởi động PHP. Lỗi này khá giống một E_WARNING trong PHP Core 4
64 E_COMPILE_ERROR Fatal compile-time error. Các lỗi này khá giống một E_ERROR được tạo bởi Zend Scripting Engine 4
128 E_COMPILE_WARNING Non-fatal compile-time error. Các lỗi này khá giống một E_WARNING được tạo bởi Zend Scripting Engine 4
256 E_USER_ERROR Fatal user-generated error. Một lỗi nghiêm trọng do người dùng tạo, giống một E_ERROR được thiết lập bởi lập trình viên bởi sử dụng hàm function trigger_error() trong PHP 4
512 E_USER_WARNING Non-fatal user-generated warning. Do người dùng tạo, giống một E_WARNING được thiết lập bởi lập trình viên bởi sử dụng hàm trigger_error() trong PHP 4
1024 E_USER_NOTICE User-generated notice. Do người dùng tạo, giống một E_NOTICE được thiết lập bởi lập trình viên bởi sử dụng hàm trigger_error() trong PHP 4
2048 E_STRICT Run-time notice. PHP gợi ý thay đổi code của bạn để làm code có tính tích hợp và hoạt động liên kết hơn 5
4096 E_RECOVERABLE_ERROR Catchable fatal error. Giống một E_ERROR nhưng có thể được bắt bởi handle do người dùng định nghĩa (bạn cũng tham khảo hàm set_error_handler()) 5
8191 E_ALL Tất cả Error và warning, ngoại trừ E_STRICT 5

Danh sách hàm xử lý lỗi và xử lý log trong PHP

Để chạy các ví dụ, bạn sao chép phần PHP code vào phần // Phần PHP code ở dưới đây và sau đó lưu chương trình trên trong một file có tên là test.php trong htdocs, sau đó mở trình duyệt và gõ địa chỉ http://localhost:8080/test.php sẽ cho kết quả.


   
   
      Hàm trong PHP
   
   
   
       
       // Phần PHP code
       
   

Cột PHP chỉ phiên bản PHP sớm nhất mà hỗ trợ hàm đó.

Hàm Miêu tả PHP
Hàm debug_backtrace() Tạo một Backtrace 4
Hàm debug_print_backtrace() In một Backtrace 5
Hàm error_get_last() Lấy lỗi cuối cùng đã xảy ra 5
Hàm error_log() Gửi một lỗi tới Server Error-Log, tới một File hoặc một Remote Destination 4
Hàm error_reporting() Xác định lỗi nào được báo cáo 4
Hàm restore_error_handler() Phục hồi Error Handler trước đó 4
Hàm restore_exception_handler() Phục hồi Exception Handler trước đó 5
Hàm set_error_handler() Thiết lập một hàm do người dùng tạo để xử lý lỗi 4
Hàm set_exception_handler() Thiết lập một hàm do người dùng tạo để xử lý ngoại lệ 5
Hàm trigger_error() Tạo một error message được định nghĩa bởi người dùng 4
Hàm user_error() Alias của hàm trigger_error() 4

Các bài học PHP phổ biến khác tại VietJack:


tong_hop_ham_trong_php.jsp