HEX
Server: Apache
System: Linux top 5.8.11-1.el7.elrepo.x86_64 #1 SMP Tue Sep 22 18:18:35 EDT 2020 x86_64
User: www (1000)
PHP: 7.4.33
Disabled: passthru,exec,system,putenv,chroot,chgrp,chown,shell_exec,popen,proc_open,pcntl_exec,ini_alter,ini_restore,dl,openlog,syslog,readlink,symlink,popepassthru,pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wifcontinued,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,imap_open,apache_setenv
Upload Files
File: /www/wwwroot/www.018111.cn/wp-content/themes/jian/inc/admin/pages/pay_log.php
<?php

// Exit if accessed directly.
defined('ABSPATH') || exit;
global $wpdb, $order_table_name,$paylog_table_name,$coupon_table_name,$balance_log_table_name,$ref_log_table_name,$down_log_table_name;
// Authentication
if ( ! current_user_can( 'manage_options' ) ) {
    return;
}
$RiPlusTable = new RiPlus_List_Table();
$RiPlusTable->prepare_items();

$message = '';
if ('delete' === $RiPlusTable->current_action()) {
    $message = '<div class="updated notice notice-success is-dismissible"><p>' . sprintf(__('成功删除: %d 条记录', 'cao'), count($_REQUEST['wp_list_event'])) . '</p></div>';
    unset($_REQUEST['wp_list_event']);
}

?>

<!-- 主页面 -->
<div class="wrap">
    <h2 >站内资源订单(包括文章订单和开通会员订单)</h2>
    <p>如需清理订单,直接筛选出未付款订单,选择删除,应用即可</p>

    <?php echo $message; ?>
    <hr class="wp-header-end">
   
    <div id="post-body-content">
        <div class="meta-box-sortables ui-sortable">
            <form method="get">
                <?php $RiPlusTable->search_box('根据文章ID搜索', 'post_id'); ?>
                <input type="hidden" name="page" value="<?php echo $_GET['page']?>">
                <?php $RiPlusTable->display(); ?>
            </form>
        </div>
    </div>
    <br class="clear">
</div>

<?php
if( ! class_exists( 'WP_List_Table' ) ) {
    require_once( ABSPATH . 'wp-admin/includes/class-wp-list-table.php' );
}

/**
 * Create a new table class that will extend the WP_List_Table
 */
class RiPlus_List_Table extends WP_List_Table
{

    public function __construct()
    {
        global $status, $page;

        parent::__construct(array(
            'singular'  => 'wp_list_event',
            'plural'    => 'wp_list_events',
            'ajax'      => false
        ));
    }



    public function no_items() {
      _e( '没有找到相关数据' );
    }

    public function prepare_items()
    {
        $columns = $this->get_columns();
        $hidden = $this->get_hidden_columns();
        $sortable = $this->get_sortable_columns();

        $per_page     = 20;
        $current_page = $this->get_pagenum();
        $total_items  = $this->get_pagenum();


        $this->set_pagination_args( array(
            'total_items' => $this->table_data_count(),
            'per_page'    => $per_page
        ) );

        $this->_column_headers = array($columns, $hidden, $sortable);
        
        $this->items = $this->table_data($per_page,$current_page);
        $this->process_bulk_action();
    }

    public function get_columns()
    {
       $columns = [
            'cb'      => '<input type="checkbox" />',
            'post_id'    => __( '商品名称', 'rizhuti-v2' ),
            'user_id'    => __( '用户', 'rizhuti-v2' ),
            'order_price'    => __( '售价', 'rizhuti-v2' ),
            'order_sale'    => __( '折扣', 'rizhuti-v2' ),
            'order_amount'    => __( '实际支付', 'rizhuti-v2' ),
            'pay_type'    => __( '支付方式', 'rizhuti-v2' ),

            'create_time'    => __( '下单时间', 'rizhuti-v2' ),
            'order_trade_no'    => __( '本地订单号', 'rizhuti-v2' ),
            'status'    => __( '支付状态', 'rizhuti-v2' ),
        ];

        return $columns;
    }

    public function column_default( $item, $column_name )
    {
        switch ( $column_name ) {
            case 'post_id':
                if (get_post_type($item['post_id']) != 'post') {
                    return '<span class="badge badge-danger">开通会员</span>'; 
                }else{
                   return '<a target="_blank" href='.get_permalink($item['post_id']).'>'.get_the_title($item['post_id']).'</a>'; 
                }

            case 'user_id':
                if ($author_obj = get_user_by('ID', $item['user_id'])) {
                    $u_name =$author_obj->user_login;
                }else{
                    $u_name = '游客';
                }
                return get_avatar($item['user_id'], 50).'<strong>'.$u_name.'<strong>';
            case 'order_price':
                return '<span class="badge badge-hollow">'.$item[$column_name]._cao('site_money_ua').'</span>';
            
            case 'order_amount':
                return '<span class="badge badge-hollow">'.$item[$column_name]._cao('site_money_ua').'</span>';
            case 'create_time':
                return date('Y-m-d H:i:s',$item[$column_name]);
            case 'pay_type':
                $paytypeArr=[
                    1=>['badge'=>'badge-blue','name'=>'支付宝'],
                    2=>['badge'=>'badge-primary','name'=>'微信'],
                    4=>['badge'=>'badge-primary','name'=>'PAYJS'],
                    5=>['badge'=>'badge-primary','name'=>'虎皮椒-微信'],
                    6=>['badge'=>'badge-blue','name'=>'虎皮椒-支付宝'],
                    7=>['badge'=>'badge-blue','name'=>'码支付-支付宝'],
                    8=>['badge'=>'badge-primary','name'=>'码支付-微信'],
                    9=>['badge'=>'badge-blue','name'=>'讯虎-支付宝'],
                    10=>['badge'=>'badge-primary','name'=>'讯虎-微信'],
                    11=>['badge'=>'badge-blue','name'=>'易支付-支付宝'],
                    12=>['badge'=>'badge-primary','name'=>'易支付-微信'],
                ];
                if ($item[$column_name]>90) {
                    return '<span class="badge badge-secondary">余额支付</span>';
                }else{
                    return '<span class="badge '.$paytypeArr[$item[$column_name]]['badge'].'">'.$paytypeArr[$item[$column_name]]['name'].'</span>';
                }
                return $item[$column_name];
            case 'status':
                if ($item[$column_name]==1) {
                    return '<span class="badge badge-primary">已支付</span>';
                }else{
                    return '<span class="badge badge-secondary">未支付</span>';
                }
            default:
              return $item[ $column_name ];
        }
    }

    public function get_hidden_columns()
    {
        return array();
    }

    public function get_sortable_columns()
    {
        $sortable_columns = array(
            'id' => array( 'id', true ),
            'create_time' => array( 'create_time', true ),
            'order_sale' => array( 'order_sale', true ),
            'order_price' => array( 'order_price', true ),
            'order_amount' => array( 'order_amount', true ),
        );

        return $sortable_columns;
    }

    public function display_tablenav( $which ) 
    {
        
        ?>
        
        <div class="tablenav <?php echo esc_attr( $which ); ?>">

            <div class="alignleft actions">
                <?php $this->bulk_actions(); ?>
            </div>
            <?php
            $this->extra_tablenav( $which );
            $this->pagination( $which );
            
            ?>
            <br class="clear" />
        </div>
        <?php
    }

    public function extra_tablenav( $which ) {
        global $wpdb, $testiURL, $tablename, $tablet;
        if ( $which == "top" ){
            ?>
            <div class="alignleft actions bulkactions">
            <?php
            $filter = [
                ['title'=>'未支付','id'=>'0'],
                ['title'=>'已支付','id'=>'1'],
            ];
            if( $filter ){
                ?>
                <select name="status" class="ewc-filter-status">
                    <option selected="selected" value="">支付状态</option>
                    <?php foreach( $filter as $item ){
                        $selected = '';
                        $_REQUEST['status'] = (!empty($_REQUEST['status'])) ? $_REQUEST['status'] : null ;
                        if( $_REQUEST['status'] == $item['id'] ){
                            $selected = ' selected = "selected"';   
                        }
                        echo '<option value="'.$item['id'].'"'.$selected.'>'.$item['title'].'</option>';
                    }?>
                </select>
                <button type="submit" id="post-query-submit" class="button">筛选</button> 
                <?php
            }?>  
            </div>
            <?php
        }
        if ( $which == "bottom" ){
        }
    }


    function column_cb($item)
    {
        return sprintf(
            '<input type="checkbox" name="%1$s[]" value="%2$s" />',
            $this->_args['singular'],
            $item['id']
        );
    }

    public function get_bulk_actions()
    {
        $actions = array(
            'delete'    => '删除',
        );
        return $actions;
    }

    public function process_bulk_action() {

        if ('delete' === $this->current_action()) {
            $delete_ids = (!empty($_REQUEST['wp_list_event'])) ? esc_sql( $_REQUEST['wp_list_event'] ) : null ; 

            if ($delete_ids) {
                foreach ($_REQUEST['wp_list_event'] as $event) {
                    $this->delete_table_data($event);
                }
            }
            
        }

    }

    
    private function table_data($per_page = 5, $page_number = 1 )
    {
        global $wpdb, $paylog_table_name;

        $sql = "SELECT * FROM $paylog_table_name WHERE 1=1";
        
        //根据postid查询
        if ( ! empty( $_REQUEST['s'] ) ) {
            $post_id = 0;
            if (is_numeric($_REQUEST['s'])) {
                $post_id = absint($_REQUEST['s']);
            }
            $sql .= ' AND post_id=' . esc_sql($post_id);
        }

        //状态查询
        if ( isset( $_REQUEST['status'] ) && $_REQUEST['status']!='' ) {
            $status = absint($_REQUEST['status']);
            $sql .= ' AND status=' . esc_sql($status);
        }

        //支付方式
        if ( isset( $_REQUEST['pay_type'] ) && $_REQUEST['pay_type']!='' ) {
            $pay_type = absint($_REQUEST['pay_type']);
            $sql .= ' AND pay_type=' . esc_sql($pay_type);
        }
        
        $orderby = (!empty($_REQUEST['orderby'])) ? $_REQUEST['orderby'] : 'create_time' ;
        if ( ! empty( $orderby ) ) {
            $sql .= ' ORDER BY ' . esc_sql( $orderby );
            $sql .= ! empty( $_REQUEST['order'] ) ? ' ' . esc_sql( $_REQUEST['order'] ) : ' DESC';
        }

        $sql .= " LIMIT $per_page";
        $sql .= ' OFFSET ' . ( $page_number - 1 ) * $per_page;

        $result = $wpdb->get_results( $sql, 'ARRAY_A' );

        return $result;
    }

    private function table_data_count() {
        global $wpdb, $paylog_table_name;

        $sql = "SELECT COUNT(*) FROM $paylog_table_name WHERE 1=1";
        //根据用户查询
        
        //根据postid查询
        if ( ! empty( $_REQUEST['s'] ) ) {
            $post_id = 0;
            if (is_numeric($_REQUEST['s'])) {
                $post_id = absint($_REQUEST['s']);
            }
            $sql .= ' AND post_id=' . esc_sql($post_id);
        }

        //状态查询
        if ( isset( $_REQUEST['status'] ) && $_REQUEST['status']!='' ) {
            $status = absint($_REQUEST['status']);
            $sql .= ' AND status=' . esc_sql($status);
        }

        return $wpdb->get_var( $sql );
    }

    private function delete_table_data( $id ) {
        global $wpdb,$paylog_table_name;
        $wpdb->delete(
            "$paylog_table_name",
            [ 'id' => $id, 'status' => 0],
            [ '%d' ]
        );
    }

}