提交資料到伺服器端資料庫都是用的form表單,這是最普通最簡單提交資料的方法,填寫表單後,post提交到後臺.php文件,處理完後回到指定頁面,最後,頁面就重新刷新了一遍,顯示預想的頁面。 以下這篇文章就來透過範例來給大家詳解一下php表單提交到資料庫。

一般朋友逛一些網(wǎng)站的時候,想使用網(wǎng)站或看到更多網(wǎng)站裡的內(nèi)容,網(wǎng)站會要求用戶進行新用戶的註冊,網(wǎng)站會把新用戶的註冊資訊存入資料庫中,需要的時候再進行提取。
這樣網(wǎng)站就會先建立自己的資料庫和對應的表,我們這裡使用php建立一個簡單的資料庫和表,使用phpMyAdmin來建立MySql資料庫和表。例如建立一個test資料庫,其範例的程式碼如下所示:
<?php
// 創(chuàng)建連接
$conn = new mysqli("localhost", "uesename", "password");
// 檢測連接
if ($conn->connect_error)
{
die("連接失敗: " . $conn->connect_error);}
// 創(chuàng)建數(shù)據(jù)庫
$sql = "CREATE DATABASE test";
if ($conn->query($sql) === TRUE)
{
echo "數(shù)據(jù)庫創(chuàng)建成功";
} else {
echo "Error creating database: " . $conn->error;
}
$conn->close();
?>
然後使用CREATE TABLE 語句用於建立 MySQL 表,設定如下幾個欄位。
id ??: 它是唯一的,類型為 int ,並選擇主鍵。
uesrname : ?使用者名,類型為?varchar, 長度為30。
password : 密碼,類型為?varchar, 長度為30。
confirm:確認密碼,類型為?varchar,長度為30。
email : ?郵箱,類型為?varchar, 長度為30。
接著使用sql語句來建立資料庫表,其程式碼顯示如下:
<?php
// 創(chuàng)建連接
$conn = new mysqli("localhost", "uesename", "password","test");
// 檢測連接
if ($conn->connect_error)
{
die("連接失敗: " . $conn->connect_error);
}
// 使用 sql 創(chuàng)建數(shù)據(jù)表
$sql = "CREATE TABLE login (
id INT(10) UNSIGNED AUTO_INCREMENT PRIMARY KEY,
username VARCHAR(30) NOT NULL,
password VARCHAR(30) NOT NULL,
confirm VARCHAR(30) NOT NULL,
email VARCHAR(30) NOT NULL,
)ENGINE=InnoDB DEFAULT CHARSET=utf8 ";
if ($conn->query($sql) === TRUE)
{
echo "Table MyGuests created successfully";
} else {
echo "創(chuàng)建數(shù)據(jù)表錯誤: " . $conn->error;
}
$conn->close();
?>
上面我們建立好了資料庫和表,下面建立一個簡單的表單註冊的前端頁面,這裡的表單頁面很簡單,使用者名,密碼,密碼確認,註冊郵箱等等幾個簡單的文字方塊。其程式碼如下:
<!DOCTYPE html>
<html>
<head>
<title>用戶注冊頁面</title>
<meta charset="UTF-8"/>
<style type="text/css">
*{margin:0px;padding:0px;}
ul{
width:400px;
list-style:none;
margin:50px auto;
}
li{
padding:12px;
position:relative;
}
label{
width:80px;
display:inline-block;
float:left;
line-height:30px;
}
input[type='text'],input[type='password']{
height:30px;
}
img{
margin-left:10px;
}
input[type="submit"]{
margin-left:80px;
padding:5px 10px;
}
</style>
</head>
<body>
<form action="zhuce.php" method="post">
<ul>
<li>
<label>用戶名:</label>
<input type="text" name="username" placeholder="請輸入注冊賬號"/>
</li>
<li>
<label>密 碼:</label>
<input type="password" name="password" placeholder="請輸入密碼" />
</li>
<li>
<label>確認密碼:</label>
<input type="password" name="confirm" placeholder="請再次輸入密碼" />
</li>
<li>
<label>郵 箱:</label>
<input type="text" name="email" placeholder="請輸入郵箱"/>
</li>
<li>
<input type="submit" value="注冊" />
</li>
</ul>
</form>
</body>
</html>
接下來就需要使用php程式碼來實作新使用者提交的資訊給提交到資料庫,使用POST方式進行值的傳遞和取得。
首先需要連接前面建立完成的資料庫和表,因為新用戶註冊的用戶名,密碼等資訊需要儲存到表中的對應欄位裡面。存入資料庫表之前先對提交的資料進行一些判斷驗證,例如不符合要求的用戶名,郵箱等需要有過濾和錯誤的提示,還要防止用戶名如果被其他用戶註冊,則需要提示您將不能再使用這個用戶名,這是先讀取資料庫已經(jīng)存在的用戶名,然後再進行判斷。
簡單來說就是將表單提交的資料都存入變數(shù),然後進行密碼和驗證碼的判斷,都正確以後,將使用者資訊存入資料庫並將資料庫存放使用者資訊的表中所有資料提取列印出來。
說穿了,後半句就是資料存入和提取。其具體的程式碼如下所示:
<?php
session_start();
header("Content-type:text/html;charset=utf-8");
$link = mysqli_connect('localhost','root','root','test');
if (!$link) {
die("連接失敗:".mysqli_connect_error());
}
$username = $_POST['username'];
$password = $_POST['password'];
$confirm = $_POST['confirm'];
$email = $_POST['email'];
if($username == "" || $password == "" || $confirm == "" || $email == "")
{
echo "<script>alert('信息不能為空!重新填寫');window.location.href='zhuce.html'</script>";
} elseif ((strlen($username) < 3)||(!preg_match('/^\w+$/i', $username))) {
echo "<script>alert('用戶名至少3位且不含非法字符!重新填寫');window.location.href='zhuce'</script>";
//判斷用戶名長度
}elseif(strlen($password) < 5){
echo "<script>alert('密碼至少5位!重新填寫');window.location.href='zhuce.html'</script>";
//判斷密碼長度
}elseif($password != $confirm) {
echo "<script>alert('兩次密碼不相同!重新填寫');window.location.href='zhuce.html'</script>";
//檢測兩次輸入密碼是否相同
} elseif (!preg_match('/^[\w\.]+@\w+\.\w+$/i', $email)) {
echo "<script>alert('郵箱不合法!重新填寫');window.location.href='zhuce.html'</script>";
//判斷郵箱格式是否合法
} elseif(mysqli_fetch_array(mysqli_query($link,"select * from login where username = '$username'"))){
echo "<script>alert('用戶名已存在');window.location.href='zhuce.html'</script>";
} else{
$sql= "insert into login(username, password, confirm, email)values('$username','$password','$confirm','$email')";
//插入數(shù)據(jù)庫
if(!(mysqli_query($link,$sql))){
echo "<script>alert('數(shù)據(jù)插入失敗');window.location.href='zhuce.html'</script>";
}else{
echo "<script>alert('注冊成功!)</script>";
}
}
?>
朋友們可以自己動手進行各種操作和嘗試,熟練以後就會對表單操作,資料庫的操作有一定深入的理解,為以後的開發(fā)打下良好的基礎。
以上是php表單怎麼提交到資料庫? (詳解)的詳細內(nèi)容。更多資訊請關注PHP中文網(wǎng)其他相關文章!