当前位置:首页 > PHP

php实现充值

2026-02-28 05:55:40PHP

PHP 实现充值功能

数据库设计

创建数据库表存储用户余额和充值记录:

CREATE TABLE users (
    id INT PRIMARY KEY AUTO_INCREMENT,
    username VARCHAR(50) UNIQUE,
    balance DECIMAL(10,2) DEFAULT 0.00
);

CREATE TABLE recharge_records (
    id INT PRIMARY KEY AUTO_INCREMENT,
    user_id INT,
    amount DECIMAL(10,2),
    payment_method VARCHAR(20),
    transaction_id VARCHAR(50),
    status ENUM('pending','completed','failed') DEFAULT 'pending',
    created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
    FOREIGN KEY (user_id) REFERENCES users(id)
);

充值表单页面

创建HTML表单接收充值金额和支付方式:

<form action="process_recharge.php" method="post">
    <input type="number" name="amount" min="1" step="0.01" required>
    <select name="payment_method" required>
        <option value="alipay">支付宝</option>
        <option value="wechat">微信支付</option>
        <option value="bank">银行卡</option>
    </select>
    <button type="submit">充值</button>
</form>

处理充值逻辑

创建处理充值的PHP脚本:

// process_recharge.php
session_start();
require 'db_connection.php';

if ($_SERVER['REQUEST_METHOD'] === 'POST') {
    $userId = $_SESSION['user_id'];
    $amount = floatval($_POST['amount']);
    $paymentMethod = $_POST['payment_method'];

    // 生成唯一交易ID
    $transactionId = uniqid('recharge_');

    // 记录充值订单
    $stmt = $pdo->prepare("INSERT INTO recharge_records 
        (user_id, amount, payment_method, transaction_id) 
        VALUES (?, ?, ?, ?)");
    $stmt->execute([$userId, $amount, $paymentMethod, $transactionId]);

    // 调用支付接口
    $paymentResult = callPaymentGateway($amount, $paymentMethod, $transactionId);

    if ($paymentResult['success']) {
        // 更新订单状态
        $pdo->prepare("UPDATE recharge_records SET status='completed' 
            WHERE transaction_id=?")->execute([$transactionId]);

        // 更新用户余额
        $pdo->prepare("UPDATE users SET balance=balance+? 
            WHERE id=?")->execute([$amount, $userId]);

        header("Location: recharge_success.php");
    } else {
        // 支付失败处理
        $pdo->prepare("UPDATE recharge_records SET status='failed' 
            WHERE transaction_id=?")->execute([$transactionId]);

        header("Location: recharge_failed.php");
    }
}

function callPaymentGateway($amount, $method, $transactionId) {
    // 实际项目中这里调用第三方支付API
    // 模拟返回成功
    return ['success' => true];
}

支付结果回调处理

创建处理支付回调的接口:

// payment_callback.php
require 'db_connection.php';

$transactionId = $_POST['transaction_id'];
$status = $_POST['status']; // 'success' or 'failed'

$record = $pdo->prepare("SELECT * FROM recharge_records 
    WHERE transaction_id=?")->fetch([$transactionId]);

if ($record && $record['status'] === 'pending') {
    if ($status === 'success') {
        $pdo->beginTransaction();

        try {
            // 更新订单状态
            $pdo->prepare("UPDATE recharge_records SET status='completed' 
                WHERE transaction_id=?")->execute([$transactionId]);

            // 更新用户余额
            $pdo->prepare("UPDATE users SET balance=balance+? 
                WHERE id=?")->execute([$record['amount'], $record['user_id']]);

            $pdo->commit();
            echo 'SUCCESS';
        } catch (Exception $e) {
            $pdo->rollBack();
            echo 'FAILED';
        }
    } else {
        $pdo->prepare("UPDATE recharge_records SET status='failed' 
            WHERE transaction_id=?")->execute([$transactionId]);
        echo 'FAILED';
    }
} else {
    echo 'INVALID_REQUEST';
}

安全注意事项

  1. 验证用户输入金额必须大于0
  2. 使用HTTPS保护传输数据
  3. 对支付回调进行签名验证
  4. 记录完整的操作日志
  5. 实现防重复提交机制

第三方支付集成

实际项目中需要集成支付宝、微信等官方SDK:

php实现充值

// 支付宝支付示例
function createAlipayOrder($amount, $transactionId) {
    require_once 'alipay_sdk/AopSdk.php';

    $request = new AlipayTradePagePayRequest();
    $request->setBizContent(json_encode([
        'subject' => '账户充值',
        'out_trade_no' => $transactionId,
        'total_amount' => $amount,
        'product_code' => 'FAST_INSTANT_TRADE_PAY'
    ]));

    $response = $aop->pageExecute($request);
    return $response;
}

测试充值流程

  1. 开发环境使用支付沙箱
  2. 测试各种金额边界情况
  3. 模拟支付成功和失败场景
  4. 验证余额更新准确性
  5. 检查并发充值情况下的数据一致性

标签: 充值php
分享给朋友:

相关文章

git php实现

git php实现

Git 与 PHP 的集成实现 使用 PHP 执行 Git 命令 通过 PHP 的 exec()、shell_exec() 或 passthru() 函数可以直接调用 Git 命令,适用于服务器端操作…

php实现websocket

php实现websocket

PHP 实现 WebSocket WebSocket 是一种在单个 TCP 连接上进行全双工通信的协议。PHP 可以通过多种方式实现 WebSocket 功能,以下是几种常见的方法: 使用 Ratc…

php实现mysql

php实现mysql

PHP 连接 MySQL 的基本方法 PHP 提供了多种方式与 MySQL 数据库进行交互,以下是最常用的几种方法。 使用 MySQLi 扩展 MySQLi 是 MySQL 的改进扩展,支持面向对…

php实现分类

php实现分类

PHP实现分类的方法 数据库设计 创建分类表时,通常需要包含id、名称、父级id等字段。父级id用于实现多级分类结构。 CREATE TABLE categories ( id INT AU…

php 队列的实现

php 队列的实现

PHP 队列的实现方法 使用数据库实现队列 创建一个数据表存储队列任务,包含任务ID、状态、创建时间等字段。通过SQL语句实现任务的入队和出队操作。 // 入队操作 INSERT INTO queu…

php session实现购物车

php session实现购物车

PHP Session 实现购物车 初始化 Session 确保在使用 Session 前调用 session_start() 函数。通常放在 PHP 文件的最顶部。 <?php sessio…