【问题标题】:woocommerce get order details after checkoutwoocommerce结帐后获取订单详细信息
【发布时间】:2015-10-23 23:16:18
【问题描述】:

结帐后我需要获取以下信息:

  • 订单编号
  • 订单日期
  • 客户名称(F/L)
  • 客户电话
  • 客户电子邮件

这将被放入会话数组中,然后存储在单独的数据库中。目前在我的主题的 functions.php 文件中,我有以下内容:

    //get completed order data:
    add_action( 'woocommerce_order_status_completed', 'my_function' );
    function my_function($order_id) {
    $order = new WC_Order( $order_id );
    $_SESSION['kiosk_data']['order_number'] = $order->[what would I use here?];
    $_SESSION['kiosk_data']['order_date'] = $order->[what would I use here?];
    $_SESSION['kiosk_data']['f_name'] = $order->[what would I use here?];
    $_SESSION['kiosk_data']['l_name'] = $order->[what would I use here?];
    $_SESSION['kiosk_data']['phone'] = $order->[what would I use here?];
    $_SESSION['kiosk_data']['email'] = $order->[what would I use here?];

    //for testing:
    $kioskDataFile = './testFile.txt';
    $kioskData = "kioskID: ".$_SESSION['kiosk_data']['kioskID']."\n";
    $kioskData.= "order date: ";
    $kioskData.= $order->order_date;
    $kioskData.= "\n";
    $kioskData.= "order ID: ";
    $kioskData.= $order->id;
    $kioskData.= "\n";
    $kioskData.= "order key: ";
    $kioskData.= $order->order_key;
    $kioskData.= "\n";
    $kioskData.= "first name: ";
    $kioskData.= $order->billing_first_name;
    $kioskData.= "\n";
    $kioskData.= "last name: ";
    $kioskData.= $order->billing_last_name;
    $kioskData.= "\n";
    $kioskData.= "phone: ";
    $kioskData.= $order->billing_phone;
    $kioskData.= "\n";
    $kioskData.= "email: ";
    $kioskData.= $order->billing_email;
    $kioskData.= "\n\n\n";

    file_put_contents($kioskDataFile, $kioskData, FILE_APPEND);
    }

作为 WP/woocommerce 的新手,我真的不知道如何捕获这些数据(尝试了几次谷歌搜索无济于事)。

【问题讨论】:

    标签: php wordpress woocommerce get orders


    【解决方案1】:

    您可以 var_dump 订单并检查您按顺序获得的字段。

            add_action( 'woocommerce_order_status_completed', 'my_function' ,10,1);
            function my_function($order_id) {
            $order = new WC_Order( $order_id );   
            $_SESSION['kiosk_data']['order_number'] = $order->id;
            $_SESSION['kiosk_data']['order_date'] = $order->order_date;
            $_SESSION['kiosk_data']['f_name'] = $order->billing_first_name;
            $_SESSION['kiosk_data']['l_name'] = $order->billing_last_name;
            $_SESSION['kiosk_data']['phone'] = $order->billing_email;
            $_SESSION['kiosk_data']['email'] = $order->billing_phone;
            }
    

    您可以从here 获取属性列表,您可以从 WC_Order 对象中获取。

    【讨论】:

    • 似乎仍然无法正常工作。我什至尝试将内容写入文件,但仍然没有出现(请参阅原始帖子中的编辑)。
    【解决方案2】:

    通过如下更改代码并删除“add_action”组件和函数使其正常工作,并将其移至子主题/woocommerce/checkout 下的“thankyou.php”页面。

        $kioskDataFile = './logs/kiosk_log';
    
        $kioskData['description'] = "kiosk site - thankyou.php";
        $kioskData['kiosk_id'] = $_SESSION['kiosk_data']['kioskID'];
        $kioskData['order_date'] = $order->order_date;
        $kioskData['month'] = date("m");
        $kioskData['year'] = date("Y");
        $kioskData['order_number'] = $order->get_order_number();
        $kioskData['order_id'] = $order->id;
        $kioskData['order_key'] = $order->order_key;
        $kioskData['first_name'] = $order->billing_first_name;
        $kioskData['last_name'] = $order->billing_last_name;
        $kioskData['phone'] = $order->billing_phone;
        $kioskData['email'] = $order->billing_email;
    
        $s_kioskData = serialize($kioskData);
        $s_kioskData.= "\n";
        file_put_contents($kioskDataFile, $s_kioskData, FILE_APPEND);
    

    我已经序列化了数组数据,所以我可以通过 file() 从日志文件中将其加载到数组中并对其进行排序/解析。

    【讨论】:

      猜你喜欢
      • 2017-01-17
      • 1970-01-01
      • 1970-01-01
      • 2021-07-05
      • 1970-01-01
      • 1970-01-01
      • 2018-05-20
      • 2013-03-27
      • 1970-01-01
      相关资源
      最近更新 更多