php表單怎麼提交到資料庫? (詳解)

伊谢尔伦
發布: 2023-03-07 15:48:01
原創
22580 人瀏覽過

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

php表單怎麼提交到資料庫? (詳解)

一般朋友逛一些網站的時候,想使用網站或看到更多網站裡的內容,網站會要求用戶進行新用戶的註冊,網站會把新用戶的註冊資訊存入資料庫中,需要的時候再進行提取。

這樣網站就會先建立自己的資料庫和對應的表,我們這裡使用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 表,設定如下幾個欄位。

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=&#39;text&#39;],input[type=&#39;password&#39;]{
      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(&#39;localhost&#39;,&#39;root&#39;,&#39;root&#39;,&#39;test&#39;);
if (!$link) {
 die("连接失败:".mysqli_connect_error());
}
$username = $_POST[&#39;username&#39;];
$password = $_POST[&#39;password&#39;];
$confirm = $_POST[&#39;confirm&#39;];
$email = $_POST[&#39;email&#39;];
if($username == "" || $password == "" || $confirm == "" || $email == "")
{
 echo "<script>alert(&#39;信息不能为空!重新填写&#39;);window.location.href=&#39;zhuce.html&#39;</script>";
} elseif ((strlen($username) < 3)||(!preg_match(&#39;/^\w+$/i&#39;, $username))) {
 echo "<script>alert(&#39;用户名至少3位且不含非法字符!重新填写&#39;);window.location.href=&#39;zhuce&#39;</script>";
 //判断用户名长度
}elseif(strlen($password) < 5){
 echo "<script>alert(&#39;密码至少5位!重新填写&#39;);window.location.href=&#39;zhuce.html&#39;</script>";
 //判断密码长度
}elseif($password != $confirm) {
 echo "<script>alert(&#39;两次密码不相同!重新填写&#39;);window.location.href=&#39;zhuce.html&#39;</script>";
 //检测两次输入密码是否相同
} elseif (!preg_match(&#39;/^[\w\.]+@\w+\.\w+$/i&#39;, $email)) {
 echo "<script>alert(&#39;邮箱不合法!重新填写&#39;);window.location.href=&#39;zhuce.html&#39;</script>";
 //判断邮箱格式是否合法
}  elseif(mysqli_fetch_array(mysqli_query($link,"select * from login where username = &#39;$username&#39;"))){
 echo "<script>alert(&#39;用户名已存在&#39;);window.location.href=&#39;zhuce.html&#39;</script>";
} else{
 $sql= "insert into login(username, password, confirm, email)values(&#39;$username&#39;,&#39;$password&#39;,&#39;$confirm&#39;,&#39;$email&#39;)";
 //插入数据库
 if(!(mysqli_query($link,$sql))){
   echo "<script>alert(&#39;数据插入失败&#39;);window.location.href=&#39;zhuce.html&#39;</script>";
 }else{
   echo "<script>alert(&#39;注册成功!)</script>";
 }
}
?>
登入後複製

朋友們可以自己動手進行各種操作和嘗試,熟練以後就會對表單操作,資料庫的操作有一定深入的理解,為以後的開發打下良好的基礎。

以上是php表單怎麼提交到資料庫? (詳解)的詳細內容。更多資訊請關注PHP中文網其他相關文章!

相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板