php實現將表單內容提交到資料庫

2020-07-16 10:06:11

首先使用php建立一個簡單的資料庫和表,使用phpMyAdmin來建立MySql資料庫和表。例如建立一個test資料庫,如下:

<?php
// 建立連線
$conn = new mysqli("localhost", "uesename", "password");
// 檢測連線
if ($conn->connect_error)
{ 
 die("連線失敗: " . $conn->connect_error);}
 // 建立資料庫
 $sql = "CREATE DATABASE test";
  if ($conn->query($sql) === TRUE)
  { 
  echo "資料庫建立成功";
  } else { 
  echo "Error creating database: " . $conn->error;
  }
 $conn->close();
?>

然後使用CREATE TABLE 語句用於建立 MySQL 表,設定如下幾個欄位。

(相關學習視訊教學分享:php視訊教學

id : 它是唯一的,型別為 int ,並選擇主鍵。

uesrname : 使用者名稱,型別為 varchar, 長度為30。

password : 密碼,型別為 varchar, 長度為30。

confirm:確認密碼,型別為 varchar, 長度為30。

email : 郵箱,型別為 varchar, 長度為30。

接著使用sql語句來建立資料庫表,其程式碼顯示如下:

<?php
 // 建立連線
 $conn = new mysqli("localhost", "uesename", "password","test");
 // 檢測連線
 if ($conn->connect_error)
 { 
 die("連線失敗: " . $conn->connect_error);
 }
 // 使用 sql 建立資料表
 $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 "建立資料表錯誤: " . $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方式進行值的傳遞和獲取。

首先需要連線前面建立完成的資料庫和表,因為新使用者註冊的使用者名稱,密碼等資訊需要儲存到表中的對應欄位裡面。存入資料庫表之前先對提交的資料進行一些判斷驗證,比如不符合要求的使用者名稱,郵箱等需要有過濾和錯誤的提示,還要防止使用者名稱如果被其他使用者註冊,則需要提示您將不能再使用這個使用者名稱,這是先讀取資料庫已經存在的使用者名稱,然後進行判斷。

簡單來說就是將表單提交的資料都存入變數,然後進行密碼和驗證碼的判斷,都正確以後,將使用者資訊存入資料庫並將資料庫存放使用者資訊的表中所有資料提取列印出來。說白了,後半句就是資料存入和提取。其具體的程式碼如下所示:

<?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.][email protected]+.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')";
 //插入資料庫
 if(!(mysqli_query($link,$sql))){
 echo "<script>alert('資料插入失敗');window.location.href='zhuce.html'</script>";
 }else{
 echo "<script>alert('註冊成功!)</script>";
 }
}
?>
以上就是php實現將表單內容提交到資料庫的詳細內容,更多請關注TW511.COM其它相關文章!