亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 語言 > PHP > 正文

實例講解PHP表單驗證功能

2024-05-05 00:06:40
字體:
來源:轉載
供稿:網友

PHP 表單驗證

提示:在處理 PHP 表單時請重視安全性!

這些頁面將展示如何安全地處理 PHP 表單。對 HTML 表單數據進行適當的驗證對于防范黑客和垃圾郵件很重要!

我們稍后使用的 HTML 表單包含多種輸入字段:必需和可選的文本字段、單選按鈕以及提交按鈕:

PHP,表單驗證

上面的表單使用如下驗證規則:

 

字段 驗證規則
Name 必需。必須包含字母和空格。
E-mail 必需。必須包含有效的電子郵件地址(包含 @ 和 .)。
Website 可選。如果選填,則必須包含有效的 URL。
Comment 可選。多行輸入字段(文本框)。
Gender 必需。必須選擇一項。

 

首先我們看一下這個表單的純 HTML 代碼:

文本字段

name、email 和 website 屬于文本輸入元素,comment 字段是文本框。HTML 代碼是這樣的:

Name: <input type="text" name="name">E-mail: <input type="text" name="email">Website: <input type="text" name="website">Comment: <textarea name="comment" rows="5" cols="40"></textarea>

單選按鈕

gender 字段是單選按鈕,HTML 代碼是這樣的:

Gender:<input type="radio" name="gender" value="female">Female<input type="radio" name="gender" value="male">Male

表單元素

表單的 HTML 代碼是這樣的:

<form method="post" action="<?php echo htmlspecialchars($_SERVER["PHP_SELF"]);?>">

當提交此表單時,通過 method="post" 發送表單數據。

什么是 $_SERVER["PHP_SELF"] 變量?

$_SERVER["PHP_SELF"] 是一種超全局變量,它返回當前執行腳本的文件名。

因此,$_SERVER["PHP_SELF"] 將表單數據發送到頁面本身,而不是跳轉到另一張頁面。這樣,用戶就能夠在表單頁面獲得錯誤提示信息。

什么是 htmlspecialchars() 函數?

htmlspecialchars() 函數把特殊字符轉換為 HTML 實體。這意味著 < 和 > 之類的 HTML 字符會被替換為 < 和 > 。這樣可防止攻擊者通過在表單中注入 HTML 或 JavaScript 代碼(跨站點腳本攻擊)對代碼進行利用。

關于 PHP 表單安全性的重要提示

$_SERVER["PHP_SELF"] 變量能夠被黑客利用!

如果您的頁面使用了 PHP_SELF,用戶能夠輸入下劃線然后執行跨站點腳本(XSS)。

提示:跨站點腳本(Cross-site scripting,XSS)是一種計算機安全漏洞類型,常見于 Web 應用程序。XSS 能夠使攻擊者向其他用戶瀏覽的網頁中輸入客戶端腳本。

假設我們的一張名為 "test_form.php" 的頁面中有如下表單:

<form method="post" action="<?php echo $_SERVER["PHP_SELF"];?>">

現在,如果用戶進入的是地址欄中正常的 URL:"http://www.example.com/test_form.php",上面的代碼會轉換為:

<form method="post" action="test_form.php">

到目前,一切正常。

不過,如果用戶在地址欄中鍵入了如下 URL:

http://www.example.com/test_form.php/%22%3E%3Cscript%3Ealert('hacked')%3C/script%3E

在這種情況下,上面的代碼會轉換為:

<form method="post" action="test_form.php"/><script>alert('hacked')</script>

這段代碼加入了一段腳本和一個提示命令。并且當此頁面加載后,就會執行 JavaScript 代碼(用戶會看到一個提示框)。這僅僅是一個關于 PHP_SELF 變量如何被利用的簡單無害案例。

您應該意識到 <script> 標簽內能夠添加任何 JavaScript 代碼!黑客能夠把用戶重定向到另一臺服務器上的某個文件,該文件中的惡意代碼能夠更改全局變量或將表單提交到其他地址以保存用戶數據,等等。

如果避免 $_SERVER["PHP_SELF"] 被利用?

通過使用 htmlspecialchars() 函數能夠避免 $_SERVER["PHP_SELF"] 被利用。

表單代碼是這樣的:

<form method="post" action="<?php echo htmlspecialchars($_SERVER["PHP_SELF"]);?>">

htmlspecialchars() 函數把特殊字符轉換為 HTML 實體?,F在,如果用戶試圖利用 PHP_SELF 變量,會導致如下輸出:

<form method="post" action="test_form.php/"><script>alert('hacked')</script>">

無法利用,沒有危害!

通過 PHP 驗證表單數據

我們要做的第一件事是通過 PHP 的 htmlspecialchars() 函數傳遞所有變量。

在我們使用 htmlspecialchars() 函數后,如果用戶試圖在文本字段中提交以下內容:

<script>location.href('http://www.hacked.com')</script>

- 代碼不會執行,因為會被保存為轉義代碼,就像這樣:

現在這條代碼顯示在頁面上或 e-mail 中是安全的。

在用戶提交該表單時,我們還要做兩件事:

  1. (通過 PHP trim() 函數)去除用戶輸入數據中不必要的字符(多余的空格、制表符、換行)
  2. (通過 PHP stripslashes() 函數)刪除用戶輸入數據中的反斜杠(/)

接下來我們創建一個檢查函數(相比一遍遍地寫代碼,這樣效率更好)。

我們把函數命名為 test_input()。

現在,我們能夠通過 test_input() 函數檢查每個 $_POST 變量,腳本是這樣的:

實例

<?php// 定義變量并設置為空值$name = $email = $gender = $comment = $website = "";if ($_SERVER["REQUEST_METHOD"] == "POST") { $name = test_input($_POST["name"]); $email = test_input($_POST["email"]); $website = test_input($_POST["website"]); $comment = test_input($_POST["comment"]); $gender = test_input($_POST["gender"]);}function test_input($data) { $data = trim($data); $data = stripslashes($data); $data = htmlspecialchars($data); return $data;}?>

請注意在腳本開頭,我們檢查表單是否使用 $_SERVER["REQUEST_METHOD"] 進行提交。如果 REQUEST_METHOD 是 POST,那么表單已被提交 - 并且應該對其進行驗證。如果未提交,則跳過驗證并顯示一個空白表單。

不過,在上面的例子中,所有輸入字段都是可選的。即使用戶未輸入任何數據,腳本也能正常工作。

下一步是制作必填輸入字段,并創建需要時使用的錯誤消息。


注:相關教程知識閱讀請移步到PHP教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
亚洲美女视频网站| 欧美日韩国产精品一区二区不卡中文| 日韩精品在线视频观看| 久久久久久久久久久免费精品| 国产精品女主播| 欧美激情第一页xxx| 欧美极品少妇xxxxⅹ裸体艺术| 欧美精品激情在线观看| 91免费看片在线| 国产精品三级久久久久久电影| 国产欧美日韩免费| 欧美插天视频在线播放| 欧美天天综合色影久久精品| 亚洲欧洲第一视频| 国产一级揄自揄精品视频| 久久久精品欧美| 精品高清一区二区三区| 日韩av在线网站| 亚洲国产私拍精品国模在线观看| 久久午夜a级毛片| 中文字幕精品国产| 亚洲精品自拍偷拍| 色樱桃影院亚洲精品影院| 精品无人区乱码1区2区3区在线| 亚洲福利视频二区| 日本一区二三区好的精华液| 91免费高清视频| 欧美午夜片欧美片在线观看| 97超碰色婷婷| 国产成人精品视| 欧美激情一区二区久久久| 国产精品爽爽爽爽爽爽在线观看| 日韩精品视频在线播放| 欧美精品videosex极品1| 国产97色在线| 午夜精品一区二区三区视频免费看| 欧美香蕉大胸在线视频观看| 成人动漫网站在线观看| 欧美日韩国产精品| 亚洲最大激情中文字幕| 日韩免费在线播放| 欧美刺激性大交免费视频| 亚洲国产第一页| 欧美一区二区三区艳史| 亚洲精品按摩视频| 韩国福利视频一区| 中文字幕自拍vr一区二区三区| 55夜色66夜色国产精品视频| 国内精品视频在线| 亚洲国产欧美一区二区三区同亚洲| 亚洲精选在线观看| 青青久久av北条麻妃黑人| 亚洲欧美中文日韩在线v日本| 国产精品偷伦免费视频观看的| 一个人www欧美| 最近2019免费中文字幕视频三| 日韩理论片久久| 久久精品99久久香蕉国产色戒| 亚洲精品ady| 亚洲第一精品福利| 欧美极品少妇与黑人| 精品国产依人香蕉在线精品| 成人性生交大片免费看小说| 欧美精品久久一区二区| 亚洲美女av在线播放| 国产成人精品一区二区| 日韩在线小视频| 日韩国产精品一区| 91久久在线播放| 国产在线98福利播放视频| 久久久久久有精品国产| 在线日韩av观看| 亚洲精品一区久久久久久| 日韩欧美精品在线观看| 国产日韩在线看| 91成人免费观看网站| 国产视频在线观看一区二区| 国产一区玩具在线观看| 欧美电影在线观看| 日韩精品在线第一页| 亚洲人成啪啪网站| 国产精品一区二区三区免费视频| 91精品国产高清久久久久久| 亚洲欧美另类中文字幕| 国产黑人绿帽在线第一区| 亚洲精品电影网在线观看| 欧美在线视频一区| 欧美激情视频网| 在线色欧美三级视频| 91精品国产91久久久久久吃药| 久久婷婷国产麻豆91天堂| 午夜精品一区二区三区在线播放| 亚洲精品美女在线观看| 亚洲综合日韩在线| 亚洲福利视频久久| 成人精品一区二区三区电影免费| 欧美日韩激情网| 中文字幕日韩精品在线观看| 欧美视频免费在线| 国产日韩在线播放| 国产午夜精品麻豆| 久久久成人精品视频| 国外日韩电影在线观看| 成人午夜高潮视频| 国产欧美一区二区三区在线看| 国产视频亚洲精品| 亚洲欧美另类中文字幕| 欧美精品久久久久久久久| 亚洲一区亚洲二区| 日韩二区三区在线| 亚洲精品wwww| 国产精品午夜视频| 日韩专区在线观看| 91精品国产免费久久久久久| 亚洲国产美女久久久久| 久久久久久久久久国产| 国产午夜精品理论片a级探花| 国产精品福利片| 国产日韩欧美成人| 国产欧美va欧美va香蕉在| 日韩高清免费在线| 久久精品一偷一偷国产| 91高清在线免费观看| 久久免费高清视频| 7m精品福利视频导航| 亚洲免费视频网站| 在线视频日韩精品| 亚洲福利视频在线| 91色琪琪电影亚洲精品久久| 免费av在线一区| 都市激情亚洲色图| 一区二区三区天堂av| 亚洲在线视频观看| 亚洲伊人一本大道中文字幕| 国产精品午夜一区二区欲梦| 国产99久久精品一区二区永久免费| 欧美日韩亚洲网| 亚洲欧美日韩久久久久久| 亚洲成人a级网| 欧美不卡视频一区发布| 国产精品久久久久免费a∨大胸| 亚洲国产精品99| 亚洲丝袜av一区| 136fldh精品导航福利| 97成人在线视频| 国产在线视频2019最新视频| 亚洲第一福利网| 欧美一级黄色网| 亚洲男人天堂古典| 国产99视频在线观看| 欧美激情a∨在线视频播放| 久久中文字幕在线| 98精品国产高清在线xxxx天堂| 日韩av网站在线| 亚洲性日韩精品一区二区| 亚洲一区二区三区成人在线视频精品| 欧美xxxx14xxxxx性爽| 亚洲精品小视频| 久久99精品视频一区97| 欧美孕妇毛茸茸xxxx| 日本精品免费一区二区三区| 亚洲综合在线小说| 在线视频日本亚洲性| 97在线观看视频|