This article introduces how to configure php.ini to implement the PHP file upload function. This involves the upload_tmp_dir, upload_max_filesize, post_max_size and other options in the php.ini configuration file. These options are the key to the success or failure of file uploading. We take the Windows version of php.5.3.5 as an example.
Open the php.ini configuration file with a text tool (EditPlus is recommended) and look for File Uploads. There are the following 3 options in this area:
file_uploads = On
Whether to allow HTTP file upload. The default value is On to allow HTTP file uploads, this option cannot be set to Off.
upload_tmp_dir =
Temporary storage directory for file uploads. If not specified, PHP will use the system's default temporary directory. This option is empty by default. This option is easy to forget when manually configuring the PHP running environment. If this option is not configured, the file upload function cannot be implemented. You must assign a value to this option, such as upload_tmp_dir = "d:/fileuploadtmp". It means that there is a fileuploadtmp directory in the D drive directory, and read and write permissions are given to this directory.
upload_max_filesize = 2M
Maximum size of uploaded files. The default value of this option is 2M, that is, the file upload size is 2M. If you want to upload a 50M file, you must set upload_max_filesize = 50M.
But just setting upload_max_filesize = 50M still cannot realize the upload function of large files. We must also modify the post_max_size option in the php.ini file.
Continue to find Data Handling in php.ini, there is 1 option in this area:
post_max_size = 8M
refers to the maximum value that can be received through form POST to PHP, including all values in the form. The default is 8M. If the POST data exceeds the limit, $_POST and $_FILES will be empty.
To upload large files, you must set the value of this option to be greater than the value of the upload_max_filesize option. For example, if you set upload_max_filesize = 50M, you can set post_max_size = 100M.
In addition, if memory limit is enabled, the value should be smaller than the value of the memory_limit option.
Continue to search for Resource Limits in php.ini. There are 3 options in this area:
max_execution_time = 30
The maximum time value (in seconds) for each PHP page to run, the default is 30 seconds. When we upload a larger file, such as a 50M file, it is likely to take several minutes to complete. However, the default PHP page execution time is 30 seconds. If it exceeds 30 seconds, the script will stop executing, which results in an error. When opening a web page. Therefore we can set the value larger, such as max_execution_time = 600. If set to 0, it means no time limit.
max_input_time = 60
The time (in seconds) used by each PHP script to parse the request data, the default is 60 seconds. When we upload large files, we can set this value larger. If set to 0, it means no time limit.
memory_limit = 128M
This option is used to set the maximum memory space that a single PHP script can apply for. This helps prevent poorly written scripts from eating up the available memory on the server. Set this to -1 if no memory constraints are required.
The default version of php5.2.0 is 8M; the default version of php.5.2.0 is 16M. Versions after php 5.2.0 default to 128M;
Suppose you want to upload a large file of 50M. Configure php.ini as follows:
file_uploads = On
upload_tmp_dir = "d:/fileuploadtmp"
upload_max_filesize = 50M
post_max_size = 100M
max_execution_time = 600
max_input_time = 600
memory_limit = 128M
Tip: You need to keep memory_limit > post_max_size > upload_max_filesize
This example is for reference only, you can adjust it according to the actual situation.