• PHP订单造假


    // 获取最近的1天的订单数据,昵称,时间。
    public function getNearestOrder()
    {
        // 获取真实订单
        $service_order = M('service_order');
        $service_order_list = $service_order->where(['first_pay_time' => ['gt', strtotime(date('Y-m-d'))]])->order('id desc')->select();
        $user = M('user');
        $true_tmp = [];
        foreach ($service_order_list as $k => &$v) {
            $tmp = [];
            $user_info = $user->where(['id' => $v['uid']])->find();
            $tmp['nickname'] = Func::encryptName2($user_info['nickname']);
            $tmp['pay_time'] = DateHelper::timeTran(date('Y-m-d H:i', $v['first_pay_time']));
            $tmp['time'] = $v['first_pay_time'];
            $true_tmp[] = $tmp;
        }
    
        // 获取Redis中的数据
        $redis = Red::create();
        $order_redis_key = C('APP_ID') . ':nearest_order_data:' . date('Y-m-d');
        $order_redis_data = $redis->get($order_redis_key);
        if (!$order_redis_data) {
            // TODO 造假 
            $user = M('user');
            $out_tmp = [];
            $user_nickname_arr = $user->order('rand()')->limit(100)->getField('nickname', true);
            for ($i = 0; $i < 10; $i++) {
                $nickname = $this->getNickName($user_nickname_arr);
                $fake_order = $this->getFakeOrder($nickname);
                $out_tmp[] = $fake_order;
            }
            // 合并
            foreach ($true_tmp as $k => $v) {
                array_unshift($out_tmp, $v);
            }
            // 去重
            $out_tmp = Func::arrayUnique($out_tmp);
            // 排序
            $order_column = array_column($out_tmp, 'time');
            array_multisort($order_column, SORT_DESC, SORT_NUMERIC, $out_tmp);
            // 存储redis
            $redis->set($order_redis_key, json_encode($out_tmp), 86400);
        } else {
            // 从redis抽取
            $order_redis_data = json_decode($order_redis_data, true);
            $out_tmp = [];
            // 重置数据
            foreach ($order_redis_data as $ok => $ov) {
                $tmp = [];
                $tmp['nickname'] = $ov['nickname'];
                $tmp['pay_time'] = DateHelper::timeTran(date('Y-m-d H:i', $ov['time']));
                $tmp['time'] = $ov['time'];
                $out_tmp[] = $tmp;
            }
    
            // 合并真实订单
            foreach ($true_tmp as $k => $v) {
                array_unshift($out_tmp, $v);
            }
            // 去重
            $out_tmp = Func::arrayUnique($out_tmp);
            // 排序
            $order_column = array_column($out_tmp, 'time');
            array_multisort($order_column, SORT_DESC, SORT_NUMERIC, $out_tmp);
    
            // 超过10分钟没有下单,造假一个订单
            if (time() - $out_tmp[0]['time'] > 600 && date('H') < 19) { // 再造一个假数据
                $user = M('user');
                $user_nickname_arr = $user->order('rand()')->limit(100)->getField('nickname', true);
                $nickname = $this->getNickName($user_nickname_arr);
                $fake_order = $this->getFakeOrder($nickname,60);
                array_unshift($out_tmp, $fake_order);
            }
            // 存储redis
            $redis->set($order_redis_key, json_encode($out_tmp), 86400);
        }
    
        $this->json->S($out_tmp);
    }
    
    protected function getFakeOrder($nickname,$duration = 3600)
    {
        $time = time() - mt_rand(0, $duration);
        $tmp['nickname'] = $nickname;
        $tmp['pay_time'] = DateHelper::timeTran(date('Y-m-d H:i', $time));
        $tmp['time'] = $time;
        return $tmp;
    }
    
    protected function getNickName($user_nickname_arr)
    {
        $head_pos = mt_rand(0, count($user_nickname_arr) - 1);
        $tail_pos = mt_rand(0, count($user_nickname_arr) - 1);
        $nickname = $user_nickname_arr[$head_pos] . $user_nickname_arr[$tail_pos];
        $nickname = Func::encryptName2($nickname);
        return $nickname;
    }
    

    模拟昵称,随机时间,数组合并,数组去重,数组排序。

  • 相关阅读:
    区块链|肖臻《区块链技术与应用》公开课之以太坊篇
    区块链|肖臻《区块链技术与应用》公开课之比特币篇
    复合数据类型
    广播变量和累加器
    mysql_基本操作
    8.10 NOI模拟赛 fzhtql SAM 后缀数组 启发式合并 dsu on tree 树状数组 set 线段树合并
    心态
    7.29 NOI 模拟赛 Stars 状压 dp
    8.2 NOI模拟赛 Palindrome dp 组合计数 分类讨论
    7.30 NOI模拟赛 B Easy Sum 分块 NTT
  • 原文地址:https://www.cnblogs.com/jiqing9006/p/12911460.html
Copyright © 2020-2023  润新知