


Knowing is knowing and not knowing is knowing. 10 knowledge points that confuse PHP beginners
[1] Variables get, post, and session cannot be transferred between pages. In the latest PHP version, automatic global variables are turned off, so to get the submitted variables from the previous page, use
$_GET['foo'],$ _POST['foo'],$_SESSION['foo'] to get. Of course, you can also modify the automatic global variables to on (php.ini to register_globals = On); considering compatibility, it is better to force yourself to familiarize yourself with the new writing method www.lampbrother.net.
Note: Super global variables in PHP
Starting from PHP 4.2.0, the default value of register_globals is off. As a result, many variables that can be used directly in the past, such as $PHP_SELF or the SESSION variable you set, cannot be used. Accessed in the form of "$variable name", this may bring you a lot of changes, but it will help improve security. To access these variables, you need to use PHP superglobal variables, as follows:
$_SERVER
Variables are set by the web server or directly associated with the execution environment of the current script. Similar to the old $HTTP_SERVER_VARS array. The previous $PHP_SELF corresponds to $_SERVER['PHP_SELF']. You can use phpinfo to view your $_SERVER variable.
$_GET
Variables submitted to the script via the HTTP GET method. Similar to the old $HTTP_GET_VARS array.
$_POST
Variables submitted to the script via the HTTP POST method. Similar to the old $HTTP_POST_VARS array.
$_COOKIE
Variables submitted to the script via the HTTP Cookies method. Similar to the old $HTTP_COOKIE_VARS array.
$_SESSION
The variable currently registered for the script session. Similar to the old $HTTP_SESSION_VARS array.
$_FILES
Variables submitted to the script via HTTP POST file upload. Similar to the old $HTTP_POST_FILES array.
$_ENV
Variables submitted by the execution environment to the script. Similar to the old $HTTP_ENV_VARS array.
==================================================== ===================
For $_FILES variable: (The file domain field is "myfile")
$_FILES['myfile']['name']
Client The original name of the machine file (including path).
$_FILES['myfile']['type']
The MIME type of the file, which requires the browser to provide support for this information, such as "image/gif".
$_FILES['myfile']['size']
The size of the uploaded file, in bytes.
$_FILES['myfile']['tmp_name']
The temporary file name (including path) stored on the server after the file is uploaded.
$_FILES['myfile']['error']
Error code related to the file upload. ['error'] was added in PHP 4.2.0.
When register_globals in php.ini is set to on, $myfile_name is equivalent to $_FILES['myfile']['name'], $myfile_type is equivalent to $_FILES['myfile']['type'], etc. .
【2】The session under win32 does not work properly
php.ini default session.save_path = /tmp
This is obviously the configuration under Linux. PHP cannot read and write the session file under win32 and the session cannot be used. Change it to one An absolute path will do, for example session.save_path = c:windowstemp.
【3】Display error messages
When display_errors in php.ini = On and error_reporting = E_ALL, all errors and prompts will be displayed. It is best to turn it on during debugging for error correction. If you use the previous php writing method, the error message will probably be Regarding undefined variables. There will be a prompt when a variable is called before being assigned. The solution is to detect or block it. For example, if $foo is displayed, you can if(isset($foo)) echo $foo or echo @$foo
【4】header already sent
This error usually occurs It appears when you use HEADER. It may be due to several reasons: 1. You PRING or ECHO before using HEADER. 2. There is a blank line in front of your current file. 3. You may have INCLUDEd a file and there is a blank line at the end of the file. Or the output will also have this error.
【5】No change after changing php.ini
Restart the web server, such as IIS, Apache, etc., and then the latest settings will be applied.
【6】Sometimes the sql statement does not work and the database operation fails. The easiest way to debug is to echo the SQL statement to see if the value of the variable can be obtained.
[7] The difference between include and require
There is not much difference between the two. If the file to be included does not exist, include will prompt a notice, and then continue to execute the following statement, require will prompt a fatal error and exit. According to the test, under the win32 platform, they are included first and then executed, so it is best not to have include or require statements in the included files, which will cause directory confusion. Maybe the situation is different under *nux, I haven't tested it yet. If you do not want a file to be included multiple times, you can use include_once or require_once## to read and write document data:
function r($file_name) {
$filenum=@fopen($file_name,"r");
@flock( $filenum,LOCK_SH);
$file_data=@fread($filenum,filesize($file_name));
@fclose($filenum);
return $file_data;
}
function w($file_name,$data,$method ="w"){
$filenum=@fopen($file_name,$method);
flock($filenum,LOCK_EX);
$file_data=fwrite($filenum,$data);
fclose($filenum);
return $file_data;
}
【8】The difference between isset() and empty()
Both are used to test variables, but isset() tests whether a variable has been assigned a value, while empty() tests whether a variable that has been assigned a value is empty. If a variable is referenced in PHP without being assigned a value, it is allowed, but there will be a notice prompt. If a variable is assigned a null value, $foo="" or $foo=0 or $foo=false, then empty($foo) returns true and isset($foo) also returns true, which means assigning a null value will not log out. a variable. To unregister a variable, use unset($foo) or $foo=NULL.
[9] The mysql query statement contains keywords
When PHP queries mysql, sometimes the mysql table name or column name contains keywords, and at this time there will be errors in the query. For example, if the table name is order, an error will occur during query. The simple way is to add `[above the tab key] to the table name or column name in the SQL statement to distinguish it, for example, select * from `order`.
【10】The method of uploading multiple files at one time through HTTP protocol
There are two ideas, which are two implementations of the same method. The specific program needs to be designed by yourself
1. Set up multiple file input boxes in the form and name them with arrays, as follows:
< ; /form >
In this way, do the following test on the server side
echo " ";
print_r($_FILES);
echo " ";
2. Set multiple settings in the form file input box, but with different names, as follows:
Do the same test on the server side:
echo " ";
print_r($_FILES);
echo " ";
The above introduces the 10 knowledge points that confuse PHP beginners, including knowing, knowing, and not knowing, not knowing, and knowing. I hope it will be helpful to friends who are interested in PHP tutorials.

ThesecrettokeepingaPHP-poweredwebsiterunningsmoothlyunderheavyloadinvolvesseveralkeystrategies:1)ImplementopcodecachingwithOPcachetoreducescriptexecutiontime,2)UsedatabasequerycachingwithRedistolessendatabaseload,3)LeverageCDNslikeCloudflareforservin

You should care about DependencyInjection(DI) because it makes your code clearer and easier to maintain. 1) DI makes it more modular by decoupling classes, 2) improves the convenience of testing and code flexibility, 3) Use DI containers to manage complex dependencies, but pay attention to performance impact and circular dependencies, 4) The best practice is to rely on abstract interfaces to achieve loose coupling.

Yes,optimizingaPHPapplicationispossibleandessential.1)ImplementcachingusingAPCutoreducedatabaseload.2)Optimizedatabaseswithindexing,efficientqueries,andconnectionpooling.3)Enhancecodewithbuilt-infunctions,avoidingglobalvariables,andusingopcodecaching

ThekeystrategiestosignificantlyboostPHPapplicationperformanceare:1)UseopcodecachinglikeOPcachetoreduceexecutiontime,2)Optimizedatabaseinteractionswithpreparedstatementsandproperindexing,3)ConfigurewebserverslikeNginxwithPHP-FPMforbetterperformance,4)

APHPDependencyInjectionContainerisatoolthatmanagesclassdependencies,enhancingcodemodularity,testability,andmaintainability.Itactsasacentralhubforcreatingandinjectingdependencies,thusreducingtightcouplingandeasingunittesting.

Select DependencyInjection (DI) for large applications, ServiceLocator is suitable for small projects or prototypes. 1) DI improves the testability and modularity of the code through constructor injection. 2) ServiceLocator obtains services through center registration, which is convenient but may lead to an increase in code coupling.

PHPapplicationscanbeoptimizedforspeedandefficiencyby:1)enablingopcacheinphp.ini,2)usingpreparedstatementswithPDOfordatabasequeries,3)replacingloopswitharray_filterandarray_mapfordataprocessing,4)configuringNginxasareverseproxy,5)implementingcachingwi

PHPemailvalidationinvolvesthreesteps:1)Formatvalidationusingregularexpressionstochecktheemailformat;2)DNSvalidationtoensurethedomainhasavalidMXrecord;3)SMTPvalidation,themostthoroughmethod,whichchecksifthemailboxexistsbyconnectingtotheSMTPserver.Impl


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

DVWA
Damn Vulnerable Web App (DVWA) is a PHP/MySQL web application that is very vulnerable. Its main goals are to be an aid for security professionals to test their skills and tools in a legal environment, to help web developers better understand the process of securing web applications, and to help teachers/students teach/learn in a classroom environment Web application security. The goal of DVWA is to practice some of the most common web vulnerabilities through a simple and straightforward interface, with varying degrees of difficulty. Please note that this software

EditPlus Chinese cracked version
Small size, syntax highlighting, does not support code prompt function

Zend Studio 13.0.1
Powerful PHP integrated development environment

VSCode Windows 64-bit Download
A free and powerful IDE editor launched by Microsoft

Dreamweaver Mac version
Visual web development tools
