ECプラットフォームでは、ユーザーが注文後、一定期間決済が行われない場合、その注文は無効な注文となります。プラットフォームでは、そのような注文をキャンセルする必要があります。この記事では、PHP言語を使用してオーダータイムアウト解除機能を実装する方法を紹介します。
1. 概要
注文タイムアウトキャンセルとは、ユーザーが注文を行った後、あらかじめ設定された時間(30分など)内に支払いが完了しない場合、システムが自動的に注文をキャンセルすることを意味します。注文。これにより、未払いの注文のバックログを回避し、注文ステータスの混乱を防ぎ、ユーザー エクスペリエンスを向上させることができます。
2. 実装のアイデア
まず、注文タイムアウトを決定する必要があります。この時間はバックグラウンドで設定できます (たとえば、30 分に設定)。タイムアウト設定では、ユーザーが操作するのに十分な時間を確保できるように、ユーザーの支払い習慣を考慮する必要があります。また、タイムアウトを設定する場合は、自社のビジネス状況に応じて調整する必要もあります。
注文タイムアウトのキャンセルを実現するための重要な手順は、スケジュールされたタスクを設定することです。システムが特定の時間間隔内で指定されたスクリプトを定期的に実行できるように、スケジュールされたタスクを作成する必要があります。
Linux システムでは、crontab を使用してスケジュールされたタスクを管理できます。具体的な手順は次のとおりです:
まずターミナルを開いてコマンドを入力します:
crontab -e
次に次の形式でファイルにタスクを追加します:
分 时 日 月 周 任务
その中で、分は分を表し、時間は時間を表し、日は日付を表し、月は月を表し、週は曜日を表し、タスクはスクリプトを表します。または実行するコマンド。
たとえば、cancel_order.php という名前の PHP スクリプトを 5 分ごとに実行する場合は、タスクを追加できます:
*/5 * * * * php /path/to/cancel_order.php
<?php // 获取数据库连接 $conn = mysqli_connect("localhost", "username", "password", "database"); // 设置订单超时时间 $timeout = 1800; // 获取超时的订单 $sql = "SELECT * FROM orders WHERE status='unpaid' 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 サイトの他の関連記事を参照してください。