Maison >développement back-end >tutoriel php >Comment mettre en œuvre un système simple de gestion des commandes en ligne en utilisant PHP

Comment mettre en œuvre un système simple de gestion des commandes en ligne en utilisant PHP

WBOY
WBOYoriginal
2023-09-25 11:13:022170parcourir

Comment mettre en œuvre un système simple de gestion des commandes en ligne en utilisant PHP

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 :

  1. Fonction de connexion : les administrateurs peuvent se connecter au système via un nom d'utilisateur et un mot de passe.
  2. Fonction de gestion des commandes : les administrateurs peuvent créer, modifier, interroger et supprimer des commandes.
  3. Fonction de liste de commandes : les administrateurs peuvent consulter la liste des commandes, filtrer et trier par conditions.
  4. Fonction de détails de la commande : les administrateurs peuvent afficher les détails de la commande, y compris le numéro de commande, les informations sur le client, les informations sur le produit, etc.
  5. Prise en charge de la base de données : le système doit utiliser la base de données MySQL pour stocker les données de commande.

3. Étapes de mise en œuvre

  1. Créer une base de données

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
);
  1. Créez une page de connexion

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.

  1. Créer une 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.

  1. Créer une page de détails de 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.

  1. Créer une page de création de commande

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.

  1. Créer une page de modification de commande et supprimer la fonction de commande

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!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn