国产av日韩一区二区三区精品,成人性爱视频在线观看,国产,欧美,日韩,一区,www.成色av久久成人,2222eeee成人天堂

首頁(yè) 後端開(kāi)發(fā) php教程 php表單怎麼提交到資料庫(kù)? (詳解)

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

Apr 22, 2017 pm 02:03 PM
php 提交 資料庫(kù) 表單

提交資料到伺服器端資料庫(kù)都是用的form表單,這是最普通最簡(jiǎn)單提交資料的方法,填寫(xiě)表單後,post提交到後臺(tái).php文件,處理完後回到指定頁(yè)面,最後,頁(yè)面就重新刷新了一遍,顯示預(yù)想的頁(yè)面。 以下這篇文章就來(lái)透過(guò)範(fàn)例來(lái)給大家詳解一下php表單提交到資料庫(kù)。

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

一般朋友逛一些網(wǎng)站的時(shí)候,想使用網(wǎng)站或看到更多網(wǎng)站裡的內(nèi)容,網(wǎng)站會(huì)要求用戶進(jìn)行新用戶的註冊(cè),網(wǎng)站會(huì)把新用戶的註冊(cè)資訊存入資料庫(kù)中,需要的時(shí)候再進(jìn)行提取。

這樣網(wǎng)站就會(huì)先建立自己的資料庫(kù)和對(duì)應(yīng)的表,我們這裡使用php建立一個(gè)簡(jiǎn)單的資料庫(kù)和表,使用phpMyAdmin來(lái)建立MySql資料庫(kù)和表。例如建立一個(gè)test資料庫(kù),其範(fàn)例的程式碼如下所示:

<?php
// 創(chuàng)建連接
$conn = new mysqli("localhost", "uesename", "password");
// 檢測(cè)連接
if ($conn->connect_error)
{    
   die("連接失敗: " . $conn->connect_error);}
   // 創(chuàng)建數(shù)據(jù)庫(kù)
   $sql = "CREATE DATABASE test";
       if ($conn->query($sql) === TRUE)
       {    
       echo "數(shù)據(jù)庫(kù)創(chuàng)建成功";
       } else {    
       echo "Error creating database: " . $conn->error;
       }
   $conn->close();
?>

然後使用CREATE TABLE 語(yǔ)句用於建立 MySQL 表,設(shè)定如下幾個(gè)欄位。

id ??: 它是唯一的,類(lèi)型為 int ,並選擇主鍵。

uesrname : ?使用者名,類(lèi)型為?varchar, 長(zhǎng)度為30。

password : 密碼,類(lèi)型為?varchar, 長(zhǎng)度為30。

confirm:確認(rèn)密碼,類(lèi)型為?varchar,長(zhǎng)度為30。

email : ?郵箱,類(lèi)型為?varchar, 長(zhǎng)度為30。

接著使用sql語(yǔ)句來(lái)建立資料庫(kù)表,其程式碼顯示如下:

<?php
   // 創(chuàng)建連接
   $conn = new mysqli("localhost", "uesename", "password","test");
   // 檢測(cè)連接
   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ù)表錯(cuò)誤: " . $conn->error;
   }
   $conn->close();
?>

上面我們建立好了資料庫(kù)和表,下面建立一個(gè)簡(jiǎn)單的表單註冊(cè)的前端頁(yè)面,這裡的表單頁(yè)面很簡(jiǎn)單,使用者名,密碼,密碼確認(rèn),註冊(cè)郵箱等等幾個(gè)簡(jiǎn)單的文字方塊。其程式碼如下:

<!DOCTYPE html>
<html>
<head>
  <title>用戶注冊(cè)頁(yè)面</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="請(qǐng)輸入注冊(cè)賬號(hào)"/>
    </li>
    <li>
      <label>密 碼:</label>
      <input type="password" name="password" placeholder="請(qǐng)輸入密碼" />
    </li>
    <li>
      <label>確認(rèn)密碼:</label>
      <input type="password" name="confirm" placeholder="請(qǐng)?jiān)俅屋斎朊艽a" />
    </li>
    <li>
      <label>郵 箱:</label>
      <input type="text" name="email" placeholder="請(qǐng)輸入郵箱"/>
    </li>
    <li>
      <input type="submit" value="注冊(cè)" />
    </li>
  </ul>
</form>
</body>
</html>

接下來(lái)就需要使用php程式碼來(lái)實(shí)作新使用者提交的資訊給提交到資料庫(kù),使用POST方式進(jìn)行值的傳遞和取得。

首先需要連接前面建立完成的資料庫(kù)和表,因?yàn)樾掠脩粼]冊(cè)的用戶名,密碼等資訊需要儲(chǔ)存到表中的對(duì)應(yīng)欄位裡面。存入資料庫(kù)表之前先對(duì)提交的資料進(jìn)行一些判斷驗(yàn)證,例如不符合要求的用戶名,郵箱等需要有過(guò)濾和錯(cuò)誤的提示,還要防止用戶名如果被其他用戶註冊(cè),則需要提示您將不能再使用這個(gè)用戶名,這是先讀取資料庫(kù)已經(jīng)存在的用戶名,然後再進(jìn)行判斷。

簡(jiǎn)單來(lái)說(shuō)就是將表單提交的資料都存入變數(shù),然後進(jìn)行密碼和驗(yàn)證碼的判斷,都正確以後,將使用者資訊存入資料庫(kù)並將資料庫(kù)存放使用者資訊的表中所有資料提取列印出來(lái)。

說(shuō)穿了,後半句就是資料存入和提取。其具體的程式碼如下所示:

<?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;信息不能為空!重新填寫(xiě)&#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位且不含非法字符!重新填寫(xiě)&#39;);window.location.href=&#39;zhuce&#39;</script>";
 //判斷用戶名長(zhǎng)度
}elseif(strlen($password) < 5){
 echo "<script>alert(&#39;密碼至少5位!重新填寫(xiě)&#39;);window.location.href=&#39;zhuce.html&#39;</script>";
 //判斷密碼長(zhǎng)度
}elseif($password != $confirm) {
 echo "<script>alert(&#39;兩次密碼不相同!重新填寫(xiě)&#39;);window.location.href=&#39;zhuce.html&#39;</script>";
 //檢測(cè)兩次輸入密碼是否相同
} elseif (!preg_match(&#39;/^[\w\.]+@\w+\.\w+$/i&#39;, $email)) {
 echo "<script>alert(&#39;郵箱不合法!重新填寫(xiě)&#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;)";
 //插入數(shù)據(jù)庫(kù)
 if(!(mysqli_query($link,$sql))){
   echo "<script>alert(&#39;數(shù)據(jù)插入失敗&#39;);window.location.href=&#39;zhuce.html&#39;</script>";
 }else{
   echo "<script>alert(&#39;注冊(cè)成功!)</script>";
 }
}
?>

朋友們可以自己動(dòng)手進(jìn)行各種操作和嘗試,熟練以後就會(huì)對(duì)表單操作,資料庫(kù)的操作有一定深入的理解,為以後的開(kāi)發(fā)打下良好的基礎(chǔ)。

以上是php表單怎麼提交到資料庫(kù)? (詳解)的詳細(xì)內(nèi)容。更多資訊請(qǐng)關(guān)注PHP中文網(wǎng)其他相關(guān)文章!

本網(wǎng)站聲明
本文內(nèi)容由網(wǎng)友自願(yuàn)投稿,版權(quán)歸原作者所有。本站不承擔(dān)相應(yīng)的法律責(zé)任。如發(fā)現(xiàn)涉嫌抄襲或侵權(quán)的內(nèi)容,請(qǐng)聯(lián)絡(luò)admin@php.cn

熱AI工具

Undress AI Tool

Undress AI Tool

免費(fèi)脫衣圖片

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅(qū)動(dòng)的應(yīng)用程序,用於創(chuàng)建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費(fèi)的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費(fèi)的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強(qiáng)大的PHP整合開(kāi)發(fā)環(huán)境

Dreamweaver CS6

Dreamweaver CS6

視覺(jué)化網(wǎng)頁(yè)開(kāi)發(fā)工具

SublimeText3 Mac版

SublimeText3 Mac版

神級(jí)程式碼編輯軟體(SublimeText3)

熱門(mén)話題

Laravel 教程
1600
29
PHP教程
1502
276
PHP調(diào)用AI智能語(yǔ)音助手 PHP語(yǔ)音交互系統(tǒng)搭建 PHP調(diào)用AI智能語(yǔ)音助手 PHP語(yǔ)音交互系統(tǒng)搭建 Jul 25, 2025 pm 08:45 PM

用戶語(yǔ)音輸入通過(guò)前端JavaScript的MediaRecorderAPI捕獲並發(fā)送至PHP後端;2.PHP將音頻保存為臨時(shí)文件後調(diào)用STTAPI(如Google或百度語(yǔ)音識(shí)別)轉(zhuǎn)換為文本;3.PHP將文本發(fā)送至AI服務(wù)(如OpenAIGPT)獲取智能回復(fù);4.PHP再調(diào)用TTSAPI(如百度或Google語(yǔ)音合成)將回復(fù)轉(zhuǎn)為語(yǔ)音文件;5.PHP將語(yǔ)音文件流式返回前端播放,完成交互。整個(gè)流程由PHP主導(dǎo)數(shù)據(jù)流轉(zhuǎn)與錯(cuò)誤處理,確保各環(huán)節(jié)無(wú)縫銜接。

如何用PHP搭建社交分享功能 PHP分享接口集成實(shí)戰(zhàn) 如何用PHP搭建社交分享功能 PHP分享接口集成實(shí)戰(zhàn) Jul 25, 2025 pm 08:51 PM

在PHP中搭建社交分享功能的核心方法是通過(guò)動(dòng)態(tài)生成符合各平臺(tái)要求的分享鏈接。 1.首先獲取當(dāng)前頁(yè)面或指定的URL及文章信息;2.使用urlencode對(duì)參數(shù)進(jìn)行編碼;3.根據(jù)各平臺(tái)協(xié)議拼接生成分享鏈接;4.在前端展示鏈接供用戶點(diǎn)擊分享;5.動(dòng)態(tài)生成頁(yè)面OG標(biāo)籤優(yōu)化分享內(nèi)容展示;6.務(wù)必對(duì)用戶輸入進(jìn)行轉(zhuǎn)義以防止XSS攻擊。該方法無(wú)需複雜認(rèn)證,維護(hù)成本低,適用於大多數(shù)內(nèi)容分享需求。

如何用PHP結(jié)合AI實(shí)現(xiàn)文本糾錯(cuò) PHP語(yǔ)法檢測(cè)與優(yōu)化 如何用PHP結(jié)合AI實(shí)現(xiàn)文本糾錯(cuò) PHP語(yǔ)法檢測(cè)與優(yōu)化 Jul 25, 2025 pm 08:57 PM

要實(shí)現(xiàn)PHP結(jié)合AI進(jìn)行文本糾錯(cuò)與語(yǔ)法優(yōu)化,需按以下步驟操作:1.選擇適合的AI模型或API,如百度、騰訊API或開(kāi)源NLP庫(kù);2.通過(guò)PHP的curl或Guzzle調(diào)用API並處理返回結(jié)果;3.在應(yīng)用中展示糾錯(cuò)信息並允許用戶選擇是否採(cǎi)納;4.使用php-l和PHP_CodeSniffer進(jìn)行語(yǔ)法檢測(cè)與代碼優(yōu)化;5.持續(xù)收集反饋並更新模型或規(guī)則以提升效果。選擇AIAPI時(shí)應(yīng)重點(diǎn)評(píng)估準(zhǔn)確率、響應(yīng)速度、價(jià)格及對(duì)PHP的支持。代碼優(yōu)化應(yīng)遵循PSR規(guī)範(fàn)、合理使用緩存、避免循環(huán)查詢、定期審查代碼,並藉助X

PHP打造博客評(píng)論系統(tǒng)變現(xiàn) PHP評(píng)論審核與防刷策略 PHP打造博客評(píng)論系統(tǒng)變現(xiàn) PHP評(píng)論審核與防刷策略 Jul 25, 2025 pm 08:27 PM

1.評(píng)論系統(tǒng)商業(yè)價(jià)值最大化需結(jié)合原生廣告精準(zhǔn)投放、用戶付費(fèi)增值服務(wù)(如上傳圖片、評(píng)論置頂)、基於評(píng)論質(zhì)量的影響力激勵(lì)機(jī)制及合規(guī)匿名數(shù)據(jù)洞察變現(xiàn);2.審核策略應(yīng)採(cǎi)用前置審核 動(dòng)態(tài)關(guān)鍵詞過(guò)濾 用戶舉報(bào)機(jī)制組合,輔以評(píng)論質(zhì)量評(píng)分實(shí)現(xiàn)內(nèi)容分級(jí)曝光;3.防刷需構(gòu)建多層防禦:reCAPTCHAv3無(wú)感驗(yàn)證、Honeypot蜜罐字段識(shí)別機(jī)器人、IP與時(shí)間戳頻率限制阻止灌水、內(nèi)容模式識(shí)別標(biāo)記可疑評(píng)論,持續(xù)迭代應(yīng)對(duì)攻擊。

PHP實(shí)現(xiàn)商品庫(kù)存管理變現(xiàn) PHP庫(kù)存同步與報(bào)警機(jī)制 PHP實(shí)現(xiàn)商品庫(kù)存管理變現(xiàn) PHP庫(kù)存同步與報(bào)警機(jī)制 Jul 25, 2025 pm 08:30 PM

PHP通過(guò)數(shù)據(jù)庫(kù)事務(wù)與FORUPDATE行鎖確保庫(kù)存扣減原子性,防止高並發(fā)超賣(mài);2.多平臺(tái)庫(kù)存一致性需依賴(lài)中心化管理與事件驅(qū)動(dòng)同步,結(jié)合API/Webhook通知及消息隊(duì)列保障數(shù)據(jù)可靠傳遞;3.報(bào)警機(jī)制應(yīng)分場(chǎng)景設(shè)置低庫(kù)存、零/負(fù)庫(kù)存、滯銷(xiāo)、補(bǔ)貨週期和異常波動(dòng)策略,並按緊急程度選擇釘釘、短信或郵件通知責(zé)任人,且報(bào)警信息需完整明確,以實(shí)現(xiàn)業(yè)務(wù)適配與快速響應(yīng)。

超越燈堆:PHP在現(xiàn)代企業(yè)體系結(jié)構(gòu)中的作用 超越燈堆:PHP在現(xiàn)代企業(yè)體系結(jié)構(gòu)中的作用 Jul 27, 2025 am 04:31 AM

PHPisstillrelevantinmodernenterpriseenvironments.1.ModernPHP(7.xand8.x)offersperformancegains,stricttyping,JITcompilation,andmodernsyntax,makingitsuitableforlarge-scaleapplications.2.PHPintegrateseffectivelyinhybridarchitectures,servingasanAPIgateway

如何用Mac搭建PHP Nginx環(huán)境 MacOS配置Nginx與PHP服務(wù)組合 如何用Mac搭建PHP Nginx環(huán)境 MacOS配置Nginx與PHP服務(wù)組合 Jul 25, 2025 pm 08:24 PM

Homebrew在Mac環(huán)境搭建中的核心作用是簡(jiǎn)化軟件安裝與管理。 1.Homebrew自動(dòng)處理依賴(lài)關(guān)係,將復(fù)雜的編譯安裝流程封裝為簡(jiǎn)單命令;2.提供統(tǒng)一的軟件包生態(tài),確保軟件安裝位置與配置標(biāo)準(zhǔn)化;3.集成服務(wù)管理功能,通過(guò)brewservices可便捷啟動(dòng)、停止服務(wù);4.便於軟件升級(jí)與維護(hù),提升系統(tǒng)安全性與功能性。

PHP中的對(duì)象關(guān)聯(lián)映射(ORM)性能調(diào)整 PHP中的對(duì)象關(guān)聯(lián)映射(ORM)性能調(diào)整 Jul 29, 2025 am 05:00 AM

避免N 1查詢問(wèn)題,通過(guò)提前加載關(guān)聯(lián)數(shù)據(jù)來(lái)減少數(shù)據(jù)庫(kù)查詢次數(shù);2.僅選擇所需字段,避免加載完整實(shí)體以節(jié)省內(nèi)存和帶寬;3.合理使用緩存策略,如Doctrine的二級(jí)緩存或Redis緩存高頻查詢結(jié)果;4.優(yōu)化實(shí)體生命週期,定期調(diào)用clear()釋放內(nèi)存以防止內(nèi)存溢出;5.確保數(shù)據(jù)庫(kù)索引存在並分析生成的SQL語(yǔ)句以避免低效查詢;6.在無(wú)需跟蹤變更的場(chǎng)景下禁用自動(dòng)變更跟蹤,改用數(shù)組或輕量模式提升性能。正確使用ORM需結(jié)合SQL監(jiān)控、緩存、批量處理和適當(dāng)優(yōu)化,在保持開(kāi)發(fā)效率的同時(shí)確保應(yīng)用性能。

See all articles