Comment utiliser PHP pour mettre en œuvre un système simple de gestion des commandes en ligne
1. Introduction
Le système de gestion des commandes en ligne est une application de commerce électronique courante qui peut aider les commerçants à gérer efficacement le processus de commande, à accélérer le traitement des commandes, et améliorer la satisfaction du Client. Cet article présentera comment utiliser PHP pour mettre en œuvre un système simple de gestion des commandes en ligne, comprenant la création, la modification, l'interrogation et la suppression de commandes. Cet article suppose que les lecteurs possèdent déjà des connaissances de base en PHP.
2. Exigences du système
Le système de gestion des commandes en ligne doit répondre aux exigences de base suivantes :
3. Étapes de mise en œuvre
Tout d'abord, nous devons créer une base de données pour stocker les données de commande. Utilisez l'instruction SQL suivante pour créer une base de données nommée « commandes » et créez une table de données nommée « order_info » pour stocker les informations sur les commandes.
CREATE DATABASE orders; USE orders; CREATE TABLE order_info ( id INT(11) AUTO_INCREMENT PRIMARY KEY, order_number VARCHAR(20) NOT NULL, customer_name VARCHAR(50) NOT NULL, total_price DECIMAL(10,2) NOT NULL, create_time TIMESTAMP DEFAULT CURRENT_TIMESTAMP );
Créez un fichier appelé "index.php" dans le répertoire racine du projet et ajoutez le code suivant :
<?php session_start(); if(isset($_POST['username']) && isset($_POST['password'])){ if($_POST['username'] === 'admin' && $_POST['password'] === 'admin'){ $_SESSION['login'] = true; header('Location: order_list.php'); exit; } } ?> <!DOCTYPE html> <html> <head> <title>登录</title> <meta charset="UTF-8"> </head> <body> <form method="POST" action="index.php"> <input type="text" name="username" placeholder="用户名"> <input type="password" name="password" placeholder="密码"> <button type="submit">登录</button> </form> </body> </html>
La page contient un simple formulaire de connexion qui, lorsque le nom d'utilisateur et le mot de passe sont correct, le statut de connexion sera enregistré dans la session et passera à la page de liste de commandes.
Créez un fichier nommé "order_list.php" dans le répertoire racine du projet et ajoutez le code suivant :
<?php session_start(); if(!isset($_SESSION['login']) || $_SESSION['login'] !== true){ header('Location: index.php'); exit; } ?> <!DOCTYPE html> <html> <head> <title>订单列表</title> <meta charset="UTF-8"> </head> <body> <h1>订单列表</h1> <a href="create_order.php">创建新订单</a> <table> <tr> <th>订单号</th> <th>客户姓名</th> <th>订单金额</th> <th>创建时间</th> <th></th> </tr> <?php // 连接数据库 $conn = new mysqli('localhost', 'root', 'password', 'orders'); if ($conn->connect_error) { die('数据库连接失败:' . $conn->connect_error); } // 查询订单列表 $sql = 'SELECT * FROM order_info ORDER BY create_time DESC'; $result = $conn->query($sql); if ($result->num_rows > 0) { while($row = $result->fetch_assoc()) { echo '<tr>'; echo '<td>'.$row['order_number'].'</td>'; echo '<td>'.$row['customer_name'].'</td>'; echo '<td>'.$row['total_price'].'</td>'; echo '<td>'.$row['create_time'].'</td>'; echo '<td><a href="order_details.php?id='.$row['id'].'">详情</a></td>'; echo '</tr>'; } } else { echo '<tr><td colspan="5">暂无订单信息</td></tr>'; } $conn->close(); ?> </table> </body> </html>
La page vérifie d'abord l'état de connexion, et si l'utilisateur n'est pas connecté dans, sautez Accédez à la page de connexion. Ensuite, il interroge la liste des commandes dans la base de données et l'affiche dans un tableau HTML. Chaque ligne affiche le numéro de commande, le nom du client, le montant de la commande, l'heure de création et un lien pour afficher les détails de la commande.
Créez un fichier nommé "order_details.php" dans le répertoire racine du projet et ajoutez le code suivant :
<?php session_start(); if(!isset($_SESSION['login']) || $_SESSION['login'] !== true){ header('Location: index.php'); exit; } if(!isset($_GET['id'])){ header('Location: order_list.php'); exit; } $id = $_GET['id']; // 连接数据库 $conn = new mysqli('localhost', 'root', 'password', 'orders'); if ($conn->connect_error) { die('数据库连接失败:' . $conn->connect_error); } // 查询订单详情 $sql = 'SELECT * FROM order_info WHERE id = '.$id; $result = $conn->query($sql); if ($result->num_rows == 0) { header('Location: order_list.php'); exit; } $row = $result->fetch_assoc(); ?> <!DOCTYPE html> <html> <head> <title>订单详情</title> <meta charset="UTF-8"> </head> <body> <h1>订单详情</h1> <p><strong>订单号:</strong><?php echo $row['order_number'];?></p> <p><strong>客户姓名:</strong><?php echo $row['customer_name'];?></p> <p><strong>订单金额:</strong><?php echo $row['total_price'];?></p> <p><strong>创建时间:</strong><?php echo $row['create_time'];?></p> <a href="edit_order.php?id=<?php echo $row['id'];?>">编辑订单</a> <a href="delete_order.php?id=<?php echo $row['id'];?>" onclick="return confirm('确认删除该订单吗?')">删除订单</a> </body> </html>
La page vérifie d'abord le statut de connexion et l'identifiant de commande, si l'utilisateur est non connecté Ou si l'identifiant de commande n'est pas transmis, il passera à la page de la liste des commandes. Ensuite, il interroge les détails de la commande dans la base de données et les affiche dans une page HTML. La page contient également des liens pour modifier les commandes et supprimer des commandes.
Créez un fichier nommé "create_order.php" dans le répertoire racine du projet et ajoutez le code suivant :
<?php session_start(); if(!isset($_SESSION['login']) || $_SESSION['login'] !== true){ header('Location: index.php'); exit; } if(isset($_POST['submit'])){ // 获取订单信息 $order_number = $_POST['order_number']; $customer_name = $_POST['customer_name']; $total_price = $_POST['total_price']; // 连接数据库 $conn = new mysqli('localhost', 'root', 'password', 'orders'); if ($conn->connect_error) { die('数据库连接失败:' . $conn->connect_error); } // 创建订单 $sql = 'INSERT INTO order_info (order_number, customer_name, total_price) VALUES ("'.$order_number.'", "'.$customer_name.'", '.$total_price.')'; $result = $conn->query($sql); if($result === true){ header('Location: order_list.php'); exit; } else { die('创建订单失败:' . $conn->error); } $conn->close(); } ?> <!DOCTYPE html> <html> <head> <title>创建订单</title> <meta charset="UTF-8"> </head> <body> <h1>创建订单</h1> <form method="POST" action="create_order.php"> <input type="text" name="order_number" placeholder="订单号"> <input type="text" name="customer_name" placeholder="客户姓名"> <input type="number" step="0.01" name="total_price" placeholder="订单金额"> <button type="submit" name="submit">创建订单</button> </form> </body> </html>
La page vérifie d'abord l'état de connexion et saute si l'utilisateur n'est pas connecté dans Accédez à la page de connexion. Il enregistre ensuite les informations de commande dans la base de données lorsque le formulaire de commande est soumis.
L'implémentation de la fonction de modification de commande est similaire à celle de création d'une commande. Ajoutez simplement le code suivant à la page "edit_order.php":
<?php session_start(); if(!isset($_SESSION['login']) || $_SESSION['login'] !== true){ header('Location: index.php'); exit; } if(!isset($_GET['id'])){ header('Location: order_list.php'); exit; } $id = $_GET['id']; // 连接数据库 $conn = new mysqli('localhost', 'root', 'password', 'orders'); if ($conn->connect_error) { die('数据库连接失败:' . $conn->connect_error); } // 查询订单详情 $sql = 'SELECT * FROM order_info WHERE id = '.$id; $result = $conn->query($sql); if ($result->num_rows == 0) { header('Location: order_list.php'); exit; } $row = $result->fetch_assoc(); if(isset($_POST['submit'])){ // 获取订单信息 $order_number = $_POST['order_number']; $customer_name = $_POST['customer_name']; $total_price = $_POST['total_price']; // 更新订单 $sql = 'UPDATE order_info SET order_number = "'.$order_number.'", customer_name = "'.$customer_name.'", total_price = '.$total_price.' WHERE id = '.$id; $result = $conn->query($sql); if($result === true){ header('Location: order_details.php?id='.$id); exit; } else { die('编辑订单失败:' . $conn->error); } $conn->close(); } ?> <!DOCTYPE html> <html> <head> <title>编辑订单</title> <meta charset="UTF-8"> </head> <body> <h1>编辑订单</h1> <form method="POST" action="edit_order.php?id=<?php echo $row['id'];?>"> <input type="text" name="order_number" placeholder="订单号" value="<?php echo $row['order_number'];?>"> <input type="text" name="customer_name" placeholder="客户姓名" value="<?php echo $row['customer_name'];?>"> <input type="number" step="0.01" name="total_price" placeholder="订单金额" value="<?php echo $row['total_price'];?>"> <button type="submit" name="submit">保存修改</button> </form> </body> </html>
L'implémentation de. la fonction de suppression de commande est similaire, ajoutez simplement le code suivant à la page "delete_order.php":
<?php session_start(); if(!isset($_SESSION['login']) || $_SESSION['login'] !== true){ header('Location: index.php'); exit; } if(!isset($_GET['id'])){ header('Location: order_list.php'); exit; } $id = $_GET['id']; // 连接数据库 $conn = new mysqli('localhost', 'root', 'password', 'orders'); if ($conn->connect_error) { die('数据库连接失败:' . $conn->connect_error); } // 删除订单 $sql = 'DELETE FROM order_info WHERE id = '.$id; $result = $conn->query($sql); if($result === true){ header('Location: order_list.php'); exit; } else { die('删除订单失败:' . $conn->error); } $conn->close(); ?>
Cette page vérifie d'abord le statut de connexion et l'identifiant de commande. Si l'utilisateur n'est pas connecté ou si l'identifiant de commande n'est pas transmis, il passe à la page de la liste des commandes. Ensuite, il supprime la commande avec l'identifiant spécifié de la base de données et accède à la page de liste des commandes.
IV.Résumé
Cet article présente comment utiliser PHP pour mettre en œuvre un système simple de gestion des commandes en ligne, comprenant la création, la modification, l'interrogation et la suppression des commandes. Grâce à l'exemple de code présenté dans cet article, les lecteurs peuvent apprendre à utiliser PHP et MySQL pour implémenter une application de commerce électronique simple afin de fournir aux commerçants une méthode de gestion des commandes plus efficace. Bien entendu, il ne s’agit que d’un exemple simple, et davantage de fonctions et de sécurité doivent être prises en compte dans les applications réelles. J'espère que cet article sera utile aux lecteurs, merci d'avoir lu !
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!