当前位置:首页 > 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表单接收充值金额和支付方式:

php实现充值

<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脚本:

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:

// 支付宝支付示例
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
分享给朋友:

相关文章

php实现分页

php实现分页

PHP实现分页的基本方法 使用LIMIT和OFFSET进行数据库查询分页。通过计算当前页码和每页显示数量,动态生成SQL语句。 $page = isset($_GET['page']) ? (int…

php实现文件上传

php实现文件上传

PHP 文件上传实现方法 在 PHP 中实现文件上传需要处理 HTML 表单和服务器端脚本。以下是详细步骤: 创建 HTML 表单 使用 enctype="multipart/form-data"…

php实现搜索

php实现搜索

PHP实现搜索功能的方法 在PHP中实现搜索功能通常涉及数据库查询和用户输入的匹配。以下是几种常见的实现方式: 使用MySQL LIKE语句 通过简单的LIKE语句实现基础搜索: $searchT…

php队列的实现

php队列的实现

PHP队列的实现方式 PHP中实现队列功能可以通过多种方式,根据需求选择适合的方案: 使用数组实现基础队列 PHP数组本身支持队列操作,利用array_push和array_shift函数:…

php搜索功能实现

php搜索功能实现

实现基本的PHP搜索功能 使用MySQL数据库和PHP实现简单的关键词搜索功能。需要确保数据库中有可供搜索的表和数据。 // 连接数据库 $conn = new mysqli('localhost…

php 队列的实现

php 队列的实现

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