以下是一个简单的基于 PHP 的电子商务平台示例,此示例包含商品展示、添加商品到购物车和结算功能。我们将使用 MySQL 数据库来存储商品信息和订单信息。 1. 数据库准备 首先创建一个名为 `ecommerce` 的数据库,然后创建 `products` 和 `orders` 表。 ```sql -- 创建数据库 CREATE DATABASE ecommerce; -- 使用数据库 USE ecommerce; -- 创建商品表 CREATE TABLE products ( id INT AUTO_INCREMENT PRIMARY KEY, name VARCHAR(255) NOT NULL, price DECIMAL(10, 2) NOT NULL, description TEXT ); -- 创建订单表 CREATE TABLE orders ( id INT AUTO_INCREMENT PRIMARY KEY, product_id INT NOT NULL, quantity INT NOT NULL, total_price DECIMAL(10, 2) NOT NULL, FOREIGN KEY (product_id) REFERENCES products(id) ); ``` 2. 连接数据库的 PHP 文件(`db_connection.php`) ```php <?php // 数据库连接配置 $servername = "localhost"; $username = "your_username"; $password = "your_password"; $dbname = "ecommerce"; // 创建连接 $conn = new mysqli($servername, $username, $password, $dbname); // 检查连接 if ($conn->connect_error) { die("连接失败: " . $conn->connect_error); } ?> ``` 3. 商品展示页面(`products.php`) ```php <?php // 包含数据库连接文件 include 'db_connection.php'; // 查询商品信息 $sql = "SELECT * FROM products"; $result = $conn->query($sql); ?> <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <title>商品列表</title> </head> <body> <h1>商品列表</h1> <ul> <?php if ($result->num_rows > 0) { while ($row = $result->fetch_assoc()) { echo "<li>"; echo $row["name"] . " - 价格: $" . $row["price"]; echo "<a href='add_to_cart.php?id=" . $row["id"] . "'>添加到购物车</a>"; echo "</li>"; } } else { echo "暂无商品。"; } ?> </ul> </body> </html> <?php // 关闭数据库连接 $conn->close(); ?> ``` 4. 添加商品到购物车页面(`add_to_cart.php`) ```php <?php // 包含数据库连接文件 include 'db_connection.php'; // 获取商品 ID $product_id = $_GET['id']; // 查询商品价格 $sql = "SELECT price FROM products WHERE id = $product_id"; $result = $conn->query($sql); if ($result->num_rows > 0) { $row = $result->fetch_assoc(); $price = $row["price"]; $quantity = 1; $total_price = $price * $quantity; // 插入订单信息 $insert_sql = "INSERT INTO orders (product_id, quantity, total_price) VALUES ($product_id, $quantity, $total_price)"; if ($conn->query($insert_sql) === TRUE) { echo "商品已添加到购物车。"; } else { echo "添加失败: " . $conn->error; } } else { echo "商品不存在。"; } // 关闭数据库连接 $conn->close(); ?> ``` 5. 结算页面(`checkout.php`) ```php <?php // 包含数据库连接文件 include 'db_connection.php'; // 查询订单信息 $sql = "SELECT p.name, o.quantity, o.total_price FROM orders o JOIN products p ON o.product_id = p.id"; $result = $conn->query($sql); $total_amount = 0; ?> <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <title>结算页面</title> </head> <body> <h1>结算页面</h1> <table> <tr> <th>商品名称</th> <th>数量</th> <th>总价</th> </tr> <?php if ($result->num_rows > 0) { while ($row = $result->fetch_assoc()) { echo "<tr>"; echo "<td>" . $row["name"] . "</td>"; echo "<td>" . $row["quantity"] . "</td>"; echo "<td>$" . $row["total_price"] . "</td>"; echo "</tr>"; $total_amount += $row["total_price"]; } } else { echo "<tr><td colspan='3'>购物车为空。</td></tr>"; } ?> <tr> <td colspan="2">总金额</td> <td>$<?php echo $total_amount; ?></td> </tr> </table> </body> </html> <?php // 关闭数据库连接 $conn->close(); ?> ``` 额外需要注意的逻辑点 1. 数据安全:在实际应用中,要对用户输入进行严格的验证和过滤,防止 SQL 注入攻击。例如,在 `add_to_cart.php` 中,直接使用 `$_GET['id']` 可能会导致安全问题,应该使用预处理语句。 2. 用户体验:可以添加更多的交互功能,如购物车中商品数量的修改、商品的删除等,以提高用户体验。 3. 性能优化:对于大量数据的查询和处理,要考虑数据库索引的使用,以提高查询性能。合理使用缓存技术可以减少数据库的访问次数。 [2025-06-04 09:15:29 | AI写代码神器 | 1455点数解答]