How to set up php.ini error reporting
How to set php.ini error reporting: First find and open the php.ini configuration file; then set the content to "error_reporting=E_ALL display_errors=On".
The operating environment of this article: windows7 system, PHP7.1 version, DELL G3 computer
PHP Turn on error display and set error reporting level
Warning: Never display any error messages in a production environment!
Display errors (display_errors) and error reporting (error_reporting) are two different things. When an error occurs in a PHP script, you can choose whether to report the error (record it in the error log) according to the settings. If display_errors is turned on in the settings, the error message will be printed to the screen at the same time.
Commonly used settings in projects
switch (ENVIRONMENT) { // 对于开发环境,报告所有错误,同时显示到屏幕上 case 'development': error_reporting(-1); ini_set('display_errors', 1); break; // 对于测试和生产环境,不显示错误,5.3 以上的版本,不报告通知、废弃方法、严格这几类错误 case 'testing': case 'production': ini_set('display_errors', 0); if (version_compare(PHP_VERSION, '5.3', '>=')) { error_reporting(E_ALL & ~E_NOTICE & ~E_DEPRECATED & ~E_STRICT & ~E_USER_NOTICE & ~E_USER_DEPRECATED); } else { error_reporting(E_ALL & ~E_NOTICE & ~E_STRICT & ~E_USER_NOTICE); } break; default: header('HTTP/1.1 503 Service Unavailable.', TRUE, 503); echo 'The application environment is not set correctly.'; exit(1); // EXIT_ERROR }
PHP predefined error constants
The official website defines all error constants, Commonly used ones are:
- E_STRICT (integer) PHP suggestions for code modifications to ensure the best interoperability and forward compatibility of the code.
- E_ALL (integer) All error and warning information except E_STRICT.
- E_ERROR (integer) Fatal runtime error. This type of error is generally an unrecoverable situation, such as a problem caused by memory allocation. The consequence is that the script terminates and does not continue to run.
- E_WARNING (integer) Runtime warning (non-fatal error). Only a prompt message is given, but the script does not terminate.
- E_PARSE (integer) Compile-time syntax parsing error. Parsing errors are generated only by the parser.
- E_NOTICE (integer) Runtime notification. Indicates that the script encounters a situation that may appear as an error, but there may also be similar notifications in scripts that can run normally.
Enable and set the display level in code
ini_set() function
For PHP, you can pass php.ini
file sets various instructions. But sometimes you need to set instructions when the script is running, then you need the ini_set()
function.
string ini_set ( string $varname , string $newvalue )
Set the value of the specified configuration option. This option will retain its new value while the script is running, and will be restored when the script ends.
For example:
ini_set('error_reporting', E_ALL); ini_set('display_errors', 'on');
error_reporting() function
error_reporting()
The function can set the error_reporting directive at runtime. PHP has many error levels. Use this function to set the level when the script is running. If the optional argument is not set, error_reporting() returns the current error reporting level.
The default value for PHP7.2 is E_ALL & ~E_NOTICE & ~E_STRICT & ~E_DEPRECATED
.
It is recommended to enable E_NOTICE during the development stage to display more possible errors.
<?php // 关闭所有PHP错误报告,相当于 ini_set('error_reporting', 0); error_reporting(0); error_reporting(E_ERROR | E_WARNING | E_PARSE); // 报告 E_NOTICE (报告未初始化的变量或捕获变量名的错误拼写) error_reporting(E_ERROR | E_WARNING | E_PARSE | E_NOTICE); // 除了 E_NOTICE,报告其他所有错误 error_reporting(E_ALL ^ E_NOTICE); // 报告所有 PHP 错误 (参见 changelog) error_reporting(E_ALL); // 报告所有 PHP 错误 error_reporting(-1); // 和 error_reporting(E_ALL); 一样 ini_set('error_reporting', E_ALL);
Modify the php.ini configuration file
error_reporting = E_ALL # 报告所有错误 display_errors = On # 显示错误
[Recommended learning: "PHP Video Tutorial"]
The above is the detailed content of How to set up php.ini error reporting. For more information, please follow other related articles on the PHP Chinese website!

Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics











How to turn off the cache in php.ini: 1. Find and open the php.ini configuration file; 2. Find the "opcache.enable" and "opcache.enable_cli" options and modify them to "opcache.enable=0" and "opcache. enable_cli=0”; 3. Save the modified file.

Wampserver is a software package that can install Apache, PHP and MySQL on Windows computers. Develop and test PHP websites on your local computer easily with Wampserver. During the development process, we may need to modify the PHP configuration file php.ini. This article will introduce how to modify the php.ini file in Wampserver.
![[Compilation and Summary] Common PHP.ini prompt errors and solutions](https://img.php.cn/upload/article/202303/20/2023032017183812389.jpg?x-oss-process=image/resize,m_fill,h_207,w_330)
PHP is a commonly used server-side scripting language that is widely used in the field of web development. However, during the PHP development process, we often encounter various problems. Among them, PHP.ini prompt error is a common problem.

PHP.ini is a PHP configuration file that is used to control the performance of PHP on the server. This file is used to set the values of some variables to control PHP at runtime. This article will show you how to modify the PHP.ini configuration file to control how PHP behaves on your server.

PHP is a very popular server-side programming language. When developing web applications using PHP, we sometimes need to set the time zone in PHP. The default time zone of PHP is "UTC (Coordinated Universal Time)", which is not the time zone we want in many cases, so we need to change the time zone setting in the php.ini file. This article will explain how to change the time zone in the php.ini file.

Solution to linuxphp.ini not taking effect: 1. Reload the php.ini configuration file; 2. Search for the configuration to be modified in the printed "phpinfo();"; 3. View the "php-fpm.conf" configuration file , check whether the configuration in php.ini is overwritten. What should I do if linuxphp.ini does not take effect? Troubleshooting the problem that modifying php.ini does not take effect in the Linux environment. The main reasons why php.ini does not take effect after modification are as follows: 1. After modifying the php.ini configuration file, the php.ini configuration file is not reloaded. 2. There are multiple php.ini configuration files. 3. The configuration in php.ini is included in other files.

Solution to the problem that changing php.ini in php7 does not work: 1. Check the path of the configuration file; 2. Modify the parameters of "php.ini" under windows; 3. Set the parameter of "post_max_size" to N of "upload_max_filesize" times; 4. Restart apache.

Migration issues in PHP7 PHP7 is the next major version of PHP. It has huge improvements in performance and security, so many websites hope to upgrade to PHP7 as soon as possible. However, upgrading to PHP7 is not always easy. Due to incompatibilities with previous versions, enterprises may need to make some modifications, usually in the application code and in the PHP configuration files. As mentioned above, the mysql extension in PHP7 has been removed, so if you were using the mysql extension in an older version of PHP, you will need to make some modifications when migrating to PHP7. You can choose to replace the mysql extension with the mysqli extension (mysqli is the "MySQLImproved" extension
