PHP 表单和用户输入

PHP 表单和用户输入


PHP 中的 $_GET 和 $_POST 变量用于检索表单中的信息,比如用户输入。


PHP 表单处理

有一点很重要的事情值得注意,当处理 HTML 表单时,PHP 能把来自 HTML 页面中的表单元素自动变成可供 PHP 脚本使用。

实例

下面的实例包含了一个 HTML 表单,带有两个输入框和一个提交按钮。

form.html 文件代码:

<html> <head> <meta charset="utf-8"> <title>菜鸟教程(runoob.com)</title> </head> <body> <form action="welcome.php" method="post"> 名字: <input type="text" name="fname"> 年龄: <input type="text" name="age"> <input type="submit" value="提交"> </form> </body> </html>

当用户填写完上面的表单并点击提交按钮时,表单的数据会被送往名为 "welcome.php" 的 PHP 文件:

welcome.php 文件代码:

欢迎<?php echo $_POST["fname"]; ?>!<br> 你的年龄是 <?php echo $_POST["age"]; ?> 岁。

通过浏览器访问演示如下:

我们将在下一章中讲解 PHP 中的 $_GET 和 $_POST 变量。


PHP 获取下拉菜单的数据

PHP 下拉菜单单选

以下实例我们设置了下拉菜单三个选项,表单使用 GET 方式获取数据,action 属性值为空表示提交到当前脚本,我们可以通过 select 的 name 属性获取下拉菜单的值:

php_form_select.php 文件代码:

<?php $q = isset($_GET['q'])? htmlspecialchars($_GET['q']) : ''; if($q) { if($q =='RUNOOB') { echo '菜鸟教程<br>http://www.runoob.com'; } else if($q =='GOOGLE') { echo 'Google 搜索<br>http://www.google.com'; } else if($q =='TAOBAO') { echo '淘宝<br>http://www.taobao.com'; } } else { ?>

<form action="" method="get"> <select name="q"> <option value="">选择一个站点:</option> <option value="RUNOOB">Runoob</option> <option value="GOOGLE">Google</option> <option value="TAOBAO">Taobao</option> </select> <input type="submit" value="提交"> </form>

<?php } ?>

PHP 下拉菜单多选

如果下拉菜单是多选的( multiple="multiple"),我们可以通过将设置 select name="q[]" 以数组的方式获取,以下使用 POST 方式提交,代码如下所示:

php_form_select_mul.php 文件代码:

<?php $q = isset($_POST['q'])? $_POST['q'] : ''; if(is_array($q)) { $sites = array( 'RUNOOB' => '菜鸟教程: http://www.runoob.com', 'GOOGLE' => 'Google 搜索: http://www.google.com', 'TAOBAO' => '淘宝: http://www.taobao.com', ); foreach($q as $val) { // PHP_EOL 为常量,用于换行 echo $sites[$val] . PHP_EOL; } } else { ?>

<form action="" method="post"> <select multiple="multiple" name="q[]"> <option value="">选择一个站点:</option> <option value="RUNOOB">Runoob</option> <option value="GOOGLE">Google</option> <option value="TAOBAO">Taobao</option> </select> <input type="submit" value="提交"> </form>

<?php } ?>


单选按钮表单

PHP 单选按钮表单中 name 属性的值是一致的,value 值是不同的,代码如下所示:

php_form_radio.php 文件代码:

<?php $q = isset($_GET['q'])? htmlspecialchars($_GET['q']) : ''; if($q) { if($q =='RUNOOB') { echo '菜鸟教程<br>http://www.runoob.com'; } else if($q =='GOOGLE') { echo 'Google 搜索<br>http://www.google.com'; } else if($q =='TAOBAO') { echo '淘宝<br>http://www.taobao.com'; } } else {

?><form action="" method="get"> <input type="radio" name="q" value="RUNOOB" />Runoob <input type="radio" name="q" value="GOOGLE" />Google <input type="radio" name="q" value="TAOBAO" />Taobao <input type="submit" value="提交"> </form>

<?php } ?>


checkbox 复选框

PHP checkbox 复选框可以选择多个值:

php_form_select_checkbox.php 文件代码:

<?php $q = isset($_POST['q'])? $_POST['q'] : ''; if(is_array($q)) { $sites = array( 'RUNOOB' => '菜鸟教程: http://www.runoob.com', 'GOOGLE' => 'Google 搜索: http://www.google.com', 'TAOBAO' => '淘宝: http://www.taobao.com', ); foreach($q as $val) { // PHP_EOL 为常量,用于换行 echo $sites[$val] . PHP_EOL; } } else {

?><form action="" method="post"> <input type="checkbox" name="q[]" value="RUNOOB"> Runoob<br> <input type="checkbox" name="q[]" value="GOOGLE"> Google<br> <input type="checkbox" name="q[]" value="TAOBAO"> Taobao<br> <input type="submit" value="提交"> </form>

<?php } ?>


表单验证

我们应该尽可能的对用户的输入进行验证(通过客户端脚本)。浏览器验证速度更快,并且可以减轻服务器的压力。

如果用户输入需要插入数据库,您应该考虑使用服务器验证。在服务器验证表单的一种好的方式是,把表单的数据传给当前页面(异步提交的方式更好),而不是跳转到不同的页面。这样用户就可以在同一张表单页面得到错误信息。用户也就更容易发现错误了。

实验要求分析: 该实验要求实现用户的登录功能,使用 Cookies 进行会话控制。具体要求如下: 1. 建立数据库 cookie,新建一张用户表 user,包含姓名字段 name 和密码字段 pwd。 2. 在 index.php 文件中,提供两个输入框,让用户输入用户名和密码,并提交表单到 login_pro.php 文件中。 3. 在 login_pro.php 文件中,使用 md5 对密码进行加密处理,并连接数据库,判断用户是否存在。 4. 如果存在,使用 header 重定向到 result.php 文件中,否则提示错误。 5. 在 result.php 文件中,输出欢迎信息。 文件目录设计: ``` - index.php - login_pro.php - result.php - assets/ - css/ - style.css - js/ - script.js ``` 其中,assets 文件夹存放静态资源,包括 CSS 和 JS 文件。 数据库设计: ``` CREATE DATABASE cookie; USE cookie; CREATE TABLE user ( id INT(11) NOT NULL AUTO_INCREMENT, name VARCHAR(50) NOT NULL, pwd VARCHAR(50) NOT NULL, PRIMARY KEY (id) ); INSERT INTO user (name, pwd) VALUES ('admin', '21232f297a57a5a743894a0e4a801fc3'); ``` 在上面的 SQL 语句中,使用 md5 对密码进行了加密处理,admin 的密码为 admin。 实验过程: 1. 在 index.php 文件中,提供两个输入框和一个提交按钮,让用户输入用户名和密码,并提交表单到 login_pro.php 文件中。 ``` <form method="post" action="login_pro.php"> <label for="name">Name:</label> <input type="text" id="name" name="name" required> <label for="pwd">Password:</label> <input type="password" id="pwd" name="pwd" required> <button type="submit">Login</button> </form> ``` 2. 在 login_pro.php 文件中,对提交的数据进行处理,使用 md5 对密码进行加密处理,并连接数据库,判断用户是否存在。 ``` <?php session_start(); if (isset($_POST['name']) && isset($_POST['pwd'])) { $name = $_POST['name']; $pwd = md5($_POST['pwd']); $conn = mysqli_connect('localhost', 'root', 'password', 'cookie'); if (!$conn) { die('Connection failed: ' . mysqli_connect_error()); } $sql = "SELECT * FROM user WHERE name='$name' AND pwd='$pwd'"; $result = mysqli_query($conn, $sql); if (mysqli_num_rows($result) > 0) { // 用户存在,设置 Cookies,并重定向到 result.php 页面 setcookie('name', $name, time()+3600); header('Location: result.php'); exit; } else { // 用户不存在,输出错误信息 echo 'Invalid username or password'; } mysqli_close($conn); } ?> ``` 3. 在 result.php 文件中,输出欢迎信息。 ``` <?php session_start(); if (isset($_COOKIE['name'])) { $name = $_COOKIE['name']; echo 'Welcome, ' . $name . '!'; } else { header('Location: index.php'); exit; } ?> ``` 最后,将 CSS 和 JS 文件引入到 HTML 页面中,美化页面和增加交互体验。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值