PHP form 表单传参明细研究
2015-01-24信息快讯网
最近一段时间一直在做基于uchome的二次开发网站,因uchome中的很多跳转都是通过参数do来控制的,一直对这种机制不是十分的明细,总有一种雾里看花的感觉。
为什么呢?因为表单的处理有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代码DOS造成用光网络带宽
php Smarty 字符比较代码
php下批量挂马和批量清马代码
php SQL Injection with MySQL
PHP的SQL注入实现(测试代码安全不错)
8个出色的WordPress SEO插件收集
zend framework多模块多布局配置
php文件上传表单摘自drupal的代码
php提交表单时判断 if($_POST[submit])与 if(isset($_POST[submit])) 的区别
array_multisort实现PHP多维数组排序示例讲解
php关于array_multisort多维数组排序的使用说明
PHP中foreach循环中使用引用要注意的地方
php图片处理:加水印、缩略图的实现(自定义函数:watermark、thumbnail)
《PHP编程最快明白》第四讲:日期、表单接收、session、cookie
php表单转换textarea换行符的方法
PHP获取表单textarea数据中的换行问题
mysql From_unixtime及UNIX_TIMESTAMP及DATE_FORMAT日期函数
php Smarty date_format [格式化时间日期]
PHP 配置文件中open_basedir选项作用
php与php MySQL 之间的关系
php 图片上传类代码
PHP源码之 ext/mysql扩展部分
php 小乘法表实现代码
php at(@)符号的用法简介
php 多个submit提交表单 处理方法
php fckeditor 调用的函数
php ignore_user_abort与register_shutdown_function 使用方法
php array_map array_multisort 高效处理多维数组排序
PHP加速 eAccelerator配置和使用指南
将数组写入txt文件 var_export
php 表单数据的获取代码
php 表单验证实现代码
防止MySQL注入或HTML表单滥用的PHP程序
PHP setcookie() cannot modify header information 的解决方法
攻克CakePHP系列三 表单数据增删改
Cannot modify header information错误解决方法
PHP下用rmdir实现删除目录的三种方法小结
php出现Cannot modify header information问题的解决方法大全
Smarty+QUICKFORM小小演示