This article will introduce to you how to receive external parameters in PHP. It has certain reference value. Friends in need can refer to it. I hope it will be helpful to everyone.
For a web language like PHP, receiving parameters is a very important ability. After all, the data passed from the front-end form or asynchronous request must be obtained for normal interactive display. Of course, this is also an essential capability for all languages capable of web development. Today we will take a look at various parameter access forms in PHP.
First, we need to prepare a static page, like the one below, which provides a form and a GET parameter in the url:
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Document</title> </head> <body> <form action="?show=1" method="post"> 姓名:<input type="text" name="name"/><br /> 电话:<input type="text" name="tel"/><br/> 地址(省):<input type="text" name="address.prov"/><br/> 地址(市):<input type="text" name="address city"/><br/> 兴趣1:<input type="text" name="interest[]"/><br/> 兴趣2:<input type="text" name="interest[]"/><br/> 兴趣3:<input type="text" name="interest[]"/><br/> 学历1:<input type="text" name="edu[one]"/><br/> 学历2:<input type="text" name="edu[two]"/><br/> <input type="submit" value="提交" > </form> </body> </html>
Normal$ _GET, $_POST method
// 正常的GET、POST echo $_GET['show'], '<br/>'; // 1 echo $_POST['name'], '<br/>'; // 提交的内容
This is the most basic and direct method of receiving parameters. GET parameters are obtained through $_GET, and POST parameters are obtained through $_POST. They do not interfere with each other.
Normal $_REQUEST method
// 使用REQUEST echo $_REQUEST['show'], '<br/>'; // 1 echo $_REQUEST['tel'], '<br/>'; // 提交的内容
$_REQUEST obtains all parameters in the request, excluding uploaded files. In other words, it includes all the contents of the three access parameter variables $_GET, $_POST and $_COOKIE (configuration required, not included by default). One thing to note here is that after PHP5.3, the parameter variable content accepted by $_REQUEST is specified by request_order in the php.ini file. By default, the value of this configuration parameter is GP, that is, GET and POST, and there is no COOKIE. I think If you want COOKIE, you need to modify it and add a C.
What if there is content with the same name in $_GET and $_POST? The order in which $_REQUEST is displayed is also based on the order of the configuration parameters, from left to right, with the latter covering the previous ones. For example, if you configure GP, the order of parameter coverage is: POST > GET, and the final display is in POST. Content.
register_globals problem
// register_globals 如果打开 echo $name, '<br/>'; // 提交的内容 echo $tel, '<br/>'; // 提交的内容
This is an unsafe configuration and is also configured in the php.ini file. Its function is to directly convert the requested parameters into variables. There is a problem of global variable pollution, so do not open it! ! ! The current php.ini file is basically turned off by default.
import_request_variables
// import_request_variables 抱歉,5.4之后已经取消了 import_request_variables('pg', 'pg_'); echo $pg_show, '<br/>'; echo $pg_name, '<br/>';
This function manually registers the contents of the specified parameter variable as a global variable. Similarly, it was also canceled after 5.4, so There are risks in all functions. Let’s find out if there has ever been such a function.
extract
extract($_POST, EXTR_PREFIX_ALL, 'ex'); echo $ex_name, '<br/>'; // 提交的内容 echo $ex_tel, '<br/>'; // 提交的内容
extract is currently supported as a method that can replace the above two parameter conversions. It is up to us to control the overwriting of existing variables, which is the second parameter. This can greatly avoid the problem of contaminating global variables in a controllable environment. Of course, the premise is that we must make sure to use it ourselves. Specifically You can find the document reference by yourself!
. and spaces in parameter names
// 参数名中的.和空格 echo $_REQUEST['address_prov'], '<br/>'; // 提交的内容 echo $_REQUEST['address_city'], '<br/>'; // 提交的内容
If the name of the input submitted by the form contains . or spaces, it will be directly converted into underscores. However, we do not recommend using . or spaces in front-end naming. Just use underscores when necessary. Do not create ambiguity between the front-end and the front-end.
The [] in the parameter name
// 参数名中的[] print_r($_REQUEST['interest']); // Array (v,....) echo '<br />'; print_r($_REQUEST['edu']); // Array (k/v,....)
When the name of the input submitted by the form is in the form of an array, that is, "interest[]" or "edu[one] " In this form, the parameters we receive will become the content of an array by default.
High-end php://input
// php://input $content = file_get_contents('php://input'); print_r($content); //name=xxx&.....
Finally, the php://input form of parameter is often used in interface development. Generally, when there are many security or parameter fields, the front end directly transfers a whole section of Body content in the form of Body Raw. At this time, it can only be obtained in this form. The original content of this Body Raw will usually be a whole paragraph of text, or it may be some encrypted content. The format can be defined by yourself. When facing a normal form, what we will receive is the original form content, just like the name=xxx&tel=xxx&.... above.
It should be noted that it cannot obtain the content when enctype="multipart/form-data" is used. At the same time, this method also replaces the $HTTP_RAW_POST_DATA global variable. Don’t use the eliminated ability anymore. Update the new version of PHP as soon as possible to use the new syntax features!
Summary
After sorting it out, I found that a simple parameter connection has so many forms and things that need attention, which is really eye-opening. It’s still the same saying, there is no end to learning, if you continue to study in depth, sooner or later you will become a master!
Test code:
https://github.com/zhangyue0503/dev-blog/blob/master/php/202002/source/%E5%8F%98%E7%9D%80%E8%8A%B1%E6%A0%B7%E6%9D%A5%E6%8E%A5%E5%8F%82%EF%BC%8CPHP%E4%B8%AD%E6%8E%A5%E6%94%B6%E5%A4%96%E9%83%A8%E5%8F%82%E6%95%B0%E7%9A%84%E6%96%B9%E5%BC%8F.php
Recommended learning: php video tutorial
The above is the detailed content of What are the ways to receive external parameters in PHP?. For more information, please follow other related articles on the PHP Chinese website!

php把负数转为正整数的方法:1、使用abs()函数将负数转为正数,使用intval()函数对正数取整,转为正整数,语法“intval(abs($number))”;2、利用“~”位运算符将负数取反加一,语法“~$number + 1”。

实现方法:1、使用“sleep(延迟秒数)”语句,可延迟执行函数若干秒;2、使用“time_nanosleep(延迟秒数,延迟纳秒数)”语句,可延迟执行函数若干秒和纳秒;3、使用“time_sleep_until(time()+7)”语句。

php除以100保留两位小数的方法:1、利用“/”运算符进行除法运算,语法“数值 / 100”;2、使用“number_format(除法结果, 2)”或“sprintf("%.2f",除法结果)”语句进行四舍五入的处理值,并保留两位小数。

判断方法:1、使用“strtotime("年-月-日")”语句将给定的年月日转换为时间戳格式;2、用“date("z",时间戳)+1”语句计算指定时间戳是一年的第几天。date()返回的天数是从0开始计算的,因此真实天数需要在此基础上加1。

php判断有没有小数点的方法:1、使用“strpos(数字字符串,'.')”语法,如果返回小数点在字符串中第一次出现的位置,则有小数点;2、使用“strrpos(数字字符串,'.')”语句,如果返回小数点在字符串中最后一次出现的位置,则有。

php字符串有下标。在PHP中,下标不仅可以应用于数组和对象,还可应用于字符串,利用字符串的下标和中括号“[]”可以访问指定索引位置的字符,并对该字符进行读写,语法“字符串名[下标值]”;字符串的下标值(索引值)只能是整数类型,起始值为0。

方法:1、用“str_replace(" ","其他字符",$str)”语句,可将nbsp符替换为其他字符;2、用“preg_replace("/(\s|\ \;||\xc2\xa0)/","其他字符",$str)”语句。

在php中,可以使用substr()函数来读取字符串后几个字符,只需要将该函数的第二个参数设置为负值,第三个参数省略即可;语法为“substr(字符串,-n)”,表示读取从字符串结尾处向前数第n个字符开始,直到字符串结尾的全部字符。


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

AI Hentai Generator
Generate AI Hentai for free.

Hot Article

Hot Tools

SAP NetWeaver Server Adapter for Eclipse
Integrate Eclipse with SAP NetWeaver application server.

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

Dreamweaver Mac version
Visual web development tools

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

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