当前位置: 首页 > 图文教程 > 网络编程 > PHP > PHP 表单提交给自己

PHP
IIS+mysql+php学习
PEAR MDB 数据库抽象层 ?? 一次编写?随处运行
数据库设计技巧(二)
数据库设计技巧(三)
PHP中通过ADO调用Access数据库
从 MySQL 导入导出大量数据的程序实现方法
MySQL中修改密码及访问限制设置详解
数据库设计范式
MySQL 查询中的分页思路的优化
Adodb 官方介绍
PHP中 ADOdb 类库介绍(二)
PHP中 ADOdb 类库介绍(一)
MySQL中各种字段的取值范围
数据库设计技巧(一)
为数据库建立索引(一)
为数据库建立索引(二)
用 PHP 实现 XML 备份 Mysql 数据库
mysql常见出错代码
浅谈php+mysql身份验证的方法
apache服务器配置全攻略

PHP 表单提交给自己


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-09-13   浏览: 43 ::
收藏到网摘: n/a

使用PHP进行Web开发,表单(Form)的使用随处可见,利用其属性Action和Method可以指定表单的内容要发送处理的URL以及如何将表单数据发送到服务器。 在大部分情况下我们指定另外一个来处理表单内容的URL地址给Action属性,但也有部分情况是需要将表单数据提交给自己的。这时候我们应该如何指定Action属性值呢?
<?php
if (isset($_POST['action']) && $_POST['action'] == 'submitted') {
print '<pre>';
print_r($_POST);
print '<a href="'. $_SERVER['PHP_SELF'] .'">Please try again</a>';
print '</pre>';
} else {
?>
<form action="<?php echo $_SERVER['PHP_SELF']; ?>" method="POST">
Name: <input type="text" name="personal[name]"><br>
Email: <input type="text" name="personal[email]"><br>
Beer: <br>
<select multiple name="beer[]">
<option value="warthog">Warthog
<option value="guinness">Guinness
</select><br>
<input type="hidden" name="action" value="submitted">
<input type="submit" name="submit" value="submit me!">
</form>
<?php
}
?>
上面的代码就实现了将表单提交给自己(注:在PHP4.1.0之前的版本请使用$_HTTP_POST_VARS替代下面代码中的$_Post变量)。这里使用了服务器变量$_Server获取当前页面的URL地址,并将其赋给表单的Action属性。这里使用了一个小小的技巧用以服务器在收到该URL请求是确定是POST请求还是GET请求。就是在表单中增加一个隐藏的变量,在处理请求时我们通过isset函数检测是否设置了这个隐藏变量,由此判断出该请求使用了POST还是GET方法。