ホームページ > バックエンド開発 > PHPの問題 > オーダータイムアウトキャンセル機能をPHPで実装する方法

オーダータイムアウトキャンセル機能をPHPで実装する方法

PHPz
リリース: 2023-04-19 09:58:33
オリジナル
1241 人が閲覧しました

ECプラットフォームでは、ユーザーが注文後、一定期間決済が行われない場合、その注文は無効な注文となります。プラットフォームでは、そのような注文をキャンセルする必要があります。この記事では、PHP言語を使用してオーダータイムアウト解除機能を実装する方法を紹介します。

1. 概要

注文タイムアウトキャンセルとは、ユーザーが注文を行った後、あらかじめ設定された時間(30分など)内に支払いが完了しない場合、システムが自動的に注文をキャンセルすることを意味します。注文。これにより、未払いの注文のバックログを回避し、注文ステータスの混乱を防ぎ、ユーザー エクスペリエンスを向上させることができます。

2. 実装のアイデア

  1. 注文タイムアウトの決定

まず、注文タイムアウトを決定する必要があります。この時間はバックグラウンドで設定できます (たとえば、30 分に設定)。タイムアウト設定では、ユーザーが操作するのに十分な時間を確保できるように、ユーザーの支払い習慣を考慮する必要があります。また、タイムアウトを設定する場合は、自社のビジネス状況に応じて調整する必要もあります。

  1. スケジュールされたタスク

注文タイムアウトのキャンセルを実現するための重要な手順は、スケジュールされたタスクを設定することです。システムが特定の時間間隔内で指定されたスクリプトを定期的に実行できるように、スケジュールされたタスクを作成する必要があります。

Linux システムでは、crontab を使用してスケジュールされたタスクを管理できます。具体的な手順は次のとおりです:

まずターミナルを開いてコマンドを入力します:

crontab -e
ログイン後にコピー

次に次の形式でファイルにタスクを追加します:

分 时 日 月 周 任务
ログイン後にコピー

その中で、分は分を表し、時間は時間を表し、日は日付を表し、月は月を表し、週は曜日を表し、タスクはスクリプトを表します。または実行するコマンド。

たとえば、cancel_order.php という名前の PHP スクリプトを 5 分ごとに実行する場合は、タスクを追加できます:

*/5 * * * * php /path/to/cancel_order.php
ログイン後にコピー
  1. 実装スクリプト
#次に、注文を自動的にキャンセルするためのスクリプトを実装する必要があります。具体的な実装手順は次のとおりです。

(1) 注文情報の取得

データベースから「未払い」のすべてのステータス (または未払いステータスに対応する他のステータス) を取得する必要があります。 ) タイムアウトしました。注文情報。

(2) 注文のキャンセル

タイムアウトした注文の場合は、注文ステータスを「キャンセル」に変更し、注文によって占められていた在庫リソースを解放する必要があります。

(3) 通知を送信する

注文がキャンセルされたことをユーザーに知らせるために、ユーザーに通知を送信する必要があります。ユーザーは電子メール、SMS、APP プッシュなどを使用して通知を受け取ることができます。

3. コード例

次のコードは、PHP を使用して注文タイムアウト キャンセル関数を実装する方法を示す簡単な例です。

<?php
// 获取数据库连接
$conn = mysqli_connect("localhost", "username", "password", "database");

// 设置订单超时时间
$timeout = 1800;

// 获取超时的订单
$sql = "SELECT * FROM orders WHERE status=&#39;unpaid&#39; AND UNIX_TIMESTAMP()-UNIX_TIMESTAMP(create_time)>$timeout";
$result = mysqli_query($conn, $sql);

while($row = mysqli_fetch_assoc($result)) {
    // 取消订单
    $sql = "UPDATE orders SET status='cancelled' WHERE id={$row['id']}";
    mysqli_query($conn, $sql);
    
    // 释放库存资源
    $sql = "UPDATE products SET stock=stock+{$row['count']} WHERE id={$row['product_id']}";
    mysqli_query($conn, $sql);
    
    // 发送通知
    $content = "您的订单#{$row['id']}已超时被取消。";
    send_notification($row['user_id'], $content);    
}

// 关闭数据库连接
mysqli_close($conn);

// 发送通知函数
function send_notification($user_id, $content) {
    // TODO: 发送通知
}
?>
ログイン後にコピー
上記のコードでは、mysqli 拡張機能を使用して MySQL データベースと対話します。具体的な手順は次のとおりです。

(1) まずデータベース接続を取得します:

$conn = mysqli_connect("localhost", "username", "password", "database");
ログイン後にコピー
(2) 次に、注文タイムアウトを設定します:

$timeout = 1800;
ログイン後にコピー
(3) 次に使用します。タイムアウトした注文情報を取得するための SQL ステートメント:

$sql = "SELECT * FROM orders WHERE status='unpaid' AND UNIX_TIMESTAMP()-UNIX_TIMESTAMP(create_time)>$timeout";
$result = mysqli_query($conn, $sql);
ログイン後にコピー
(4) タイムアウトした注文の場合、注文ステータスを「キャンセル済み」に変更し、注文によって占められていた在庫リソースを解放する必要があります:

$sql = "UPDATE orders SET status='cancelled' WHERE id={$row['id']}";
mysqli_query($conn, $sql);

$sql = "UPDATE products SET stock=stock+{$row['count']} WHERE id={$row['product_id']}";
mysqli_query($conn, $sql);
ログイン後にコピー
(5 ) 最後に、注文キャンセル通知をユーザーに送信する必要があります:

$content = "您的订单#{$row['id']}已超时被取消。";
send_notification($row['user_id'], $content);
ログイン後にコピー
4. まとめ

上記の実装により、PHP 注文を簡単に実装できます。タイムアウト解除機能。ユーザー エクスペリエンスへの影響を避けるために、タイムアウト期間を設定するときは、特定のビジネス条件を考慮する必要があることに注意してください。同時に、通知の範囲を改善するために、通知を送信する際には、さまざまなユーザーの通知方法を考慮する必要があります。最後に、ユーザーからの苦情や補償を避けるために、時間の経過とともにキャンセルされた注文に対して、適切な返金または返品の処理方法を提供する必要があります。

以上がオーダータイムアウトキャンセル機能をPHPで実装する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート