PHP form 表单传参明细研究

yipeiwu_com5年前PHP代码库
为什么呢?因为表单的处理有GET和POST两种,怎么在这两种表单中都要传递一直do参数,而且要在后台通过同样的方式获取就一直是个很困惑的问题,今天经过几个小时的实验终于搞懂了,特发此文。
GET表单:
复制代码 代码如下:

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
    <meta http-equiv="Content-Type" content="text/html;charset=gbk"/>
    <title>表单使用GET方式传值</title>
</head>
<body>
    <!-- action中的parm参数的值是无法传递到action-get.php的 -->
    <form action="action-get.php?parm=url-get" method="get">
        <p>
            姓名:<input type="text" name="name" />
            <!-- 隐藏变量传值 -->
            <input type="hidden" name="hkey" value="hvalue" />
            <!-- GET表单的隐藏变量传值可以通过$_GET["do"]获取 -->
            <input type="hidden" name="do" value="index" />
            <!-- submit不设置name属性则不会出现在url中 -->
            <input type="submit" value="提交"/>
        </p>
    </form>
</body>
</html>

处理GET表单的PHP:
复制代码 代码如下:

<pre>
<?php
    echo "参数 name 的值通过\$_GET获取为 ".$_GET["name"]." ,";
    echo "参数 name 的值通过\$_POST获取为 ".$_POST["name"]." ,";
    echo "参数 name 的值通过\$_REQUEST获取为 ".$_REQUEST["name"]." .\r\n";
    echo "参数 parm 的值通过\$_GET获取为 ".$_GET["parm"]." ,";
    echo "参数 parm 的值通过\$_POST获取为 ".$_POST["parm"]." ,";
    echo "参数 parm 的值通过\$_REQUEST获取为 ".$_REQUEST["parm"]." .\r\n";
    echo "参数 hkey 的值通过\$_GET获取为 ".$_GET["hkey"]." ,";
    echo "参数 hkey 的值通过\$_POST获取为 ".$_POST["hkey"]." ,";
    echo "参数 hkey 的值通过\$_REQUEST获取为 ".$_REQUEST["hkey"]." .\r\n";
    echo "参数 do 的值通过\$_GET获取为 ".$_GET["do"]." ,";
    echo "参数 do 的值通过\$_POST获取为 ".$_POST["do"]." ,";
    echo "参数 do 的值通过\$_REQUEST获取为 ".$_REQUEST["do"]." .\r\n";
?>
</pre>

处理结果输出:
参数 name 的值通过$_GET获取为 kj ,参数 name 的值通过$_POST获取为 ,参数 name 的值通过$_REQUEST获取为 kj .
参数 parm 的值通过$_GET获取为 ,参数 parm 的值通过$_POST获取为 ,参数 parm 的值通过$_REQUEST获取为 .
参数 hkey 的值通过$_GET获取为 hvalue ,参数 hkey 的值通过$_POST获取为 ,参数 hkey 的值通过$_REQUEST获取为 hvalue .
参数 do 的值通过$_GET获取为 index ,参数 do 的值通过$_POST获取为 ,参数 do 的值通过$_REQUEST获取为 index .
POST 表单:
复制代码 代码如下:

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
    <meta http-equiv="Content-Type" content="text/html;charset=gbk"/>
    <title>表单使用POST方式传值</title>
</head>
<body>
    <!-- action中的parm和do参数可以在action-post.php中通过$_GET方式获取 -->
    <form action="action-post.php?parm=url-post&do=index" method="post">
        <p>
            姓名:<input type="text" name="name" />
            <!-- 隐藏变量传值 -->
            <input type="hidden" name="hkey" value="hvalue" />
            <input type="submit" value="提交"/>
        </p>
    </form>
</body>
</html>

处理 POST 表单的PHP:
复制代码 代码如下:

<pre>
<?php
    echo "参数 name 的值通过\$_GET获取为 ".$_GET["name"]." ,";
    echo "参数 name 的值通过\$_POST获取为 ".$_POST["name"]." ,";
    echo "参数 name 的值通过\$_REQUEST获取为 ".$_REQUEST["name"]." .\r\n";
    echo "参数 parm 的值通过\$_GET获取为 ".$_GET["parm"]." ,";
    echo "参数 parm 的值通过\$_POST获取为 ".$_POST["parm"]." ,";
    echo "参数 parm 的值通过\$_REQUEST获取为 ".$_REQUEST["parm"]." .\r\n";
    echo "参数 hkey 的值通过\$_GET获取为 ".$_GET["hkey"]." ,";
    echo "参数 hkey 的值通过\$_POST获取为 ".$_POST["hkey"]." ,";
    echo "参数 hkey 的值通过\$_REQUEST获取为 ".$_REQUEST["hkey"]." .\r\n";
    echo "参数 do 的值通过\$_GET获取为 ".$_GET["do"]." ,";
    echo "参数 do 的值通过\$_POST获取为 ".$_POST["do"]." ,";
    echo "参数 do 的值通过\$_REQUEST获取为 ".$_REQUEST["do"]." .\r\n";
?>
</pre>

处理结果输出:
参数 name 的值通过$_GET获取为 ,参数 name 的值通过$_POST获取为 zkj ,参数 name 的值通过$_REQUEST获取为 zkj .
参数 parm 的值通过$_GET获取为 url-post ,参数 parm 的值通过$_POST获取为 ,参数 parm 的值通过$_REQUEST获取为 url-post .
参数 hkey 的值通过$_GET获取为 ,参数 hkey 的值通过$_POST获取为 hvalue ,参数 hkey 的值通过$_REQUEST获取为 hvalue .
参数 do 的值通过$_GET获取为 index ,参数 do 的值通过$_POST获取为 ,参数 do 的值通过$_REQUEST获取为 index .
结论:
   GET表单值可以通过_GET获取;但通过action的url参数设置的参数总是获取不到的
   POST表单值可以通过_POST获取;但通过action的url参数设置的参数则可以通过_GET获取到
   同一变量都可以通过_GET获取,但在GET表单中通过隐藏变量设置,在POST表单中则通过action的url参数设置

相关文章

PHP命令Command模式用法实例分析

本文实例讲述了PHP命令Command模式用法。分享给大家供大家参考,具体如下: 命令Command模式是GOF23种模式中的一种,是一种行为模式。这种模式很难理解。《设计模式》一书中对...

输入值/表单提交参数过滤有效防止sql注入的方法

输入值/表单提交参数过滤,防止sql注入或非法攻击的方法: 复制代码 代码如下: /** * 过滤sql与php文件操作的关键字 * @param string $string * @r...

解析php中session的实现原理以及大网站应用应注意的问题

PHP SESSION原理我们知道,session是在服务器端保持用户会话数据的一种方法,对应的cookie是 在客户端保持用户数据。HTTP协议是一种无状态协议,服务器响应完之后就失去...

php工具型代码之印章抠图

能将白底红字的印章抠出来,用的是php,框架是laravel,其他框架请自行调节。扣其他颜色也可以,把里面的那段rgb参数判断改改就行了,最后抠出来的效果就是白底变透明,然后只留下红色的...

php将HTML表格每行每列转为数组实现采集表格数据的方法

本文实例讲述了php将HTML表格每行每列转为数组实现采集表格数据的方法。分享给大家供大家参考。具体如下: 下面的php代码可以将HTML表格的每行每列转为数组,采集表格数据 <...