From 9a8c7713e5c8749b19f8652d46e96d5d4c02f7e1 Mon Sep 17 00:00:00 2001 From: tsf <460834639@qq.com> Date: Mon, 29 Apr 2024 16:42:30 +0800 Subject: [PATCH] =?UTF-8?q?=E6=9B=B4=E6=96=B0?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- application/app/controller/Card.php | 35 ++++--- application/app/controller/Download.php | 2 +- application/app/controller/Skip.php | 118 ++++++++++++++++++------ application/config.php | 2 +- application/route.php | 38 ++++++++ 5 files changed, 153 insertions(+), 42 deletions(-) diff --git a/application/app/controller/Card.php b/application/app/controller/Card.php index d5f5090..260cd39 100644 --- a/application/app/controller/Card.php +++ b/application/app/controller/Card.php @@ -8,10 +8,16 @@ use app\bj\controller\Common; use think\Log; use \think\Validate; use app\app\controller\Calculatebody; +use app\app\controller\Skip; class Card extends Base{ protected $color = ['#FF5656','#FFAB00','#5AD06D','#6492F6','#3967D6']; + protected $db_name = ['2'=>'app_card_body_data','6'=>'app_card_skip_data']; + protected $db_content = [ + '2'=>'height as v1,weight as v2,bmi as v3', + '6'=>'jump_num as v1,jump_time as v2,jump_kcal as v3' + ]; protected $age_limit = 16; protected $unit_symbol = ['score'=>'分','height'=>'CM','weight'=>'公斤','fat_r'=>'%','fat_w'=>'kg','muscle'=>'%','muscleval'=>'kg','water'=>'kg','bone'=>'kg','protein'=>'%','proteinval'=>'kg','kcal'=>'kcal','sfr'=>'%',]; protected $unit_name = ['score'=>'身体得分','height'=>'身高','weight'=>'体重','bmi'=>'BMI','fat_r'=>'脂肪率','fat_w'=>'脂肪量','muscle'=>'肌肉率','muscleval'=>'肌肉量','water'=>'水分','bone'=>'骨重','protein'=>'蛋白率','proteinval'=>'蛋白量','kcal'=>'基础代谢','visceral'=>'内脏指数','sfr'=>'皮下脂肪','body_level'=>'肥胖等级','body_type'=>'身体类型']; @@ -157,16 +163,18 @@ class Card extends Base{ } // 获取记录信息列表 - function get_card_record_data($data = ['acd_id'=>'2','aud_id'=>'11','s_time'=>'2024-04-01 10:10:10','e_time'=>'2024-04-12 10:10:10']){ + function get_card_record_data($data = ['acd_id'=>'6','aud_id'=>'11','s_time'=>'2024-04-01 10:10:10','e_time'=>'2024-04-12 10:10:10']){ if(!array_key_exists('acd_id', $data) || !array_key_exists('aud_id', $data) || !array_key_exists('s_time', $data) || !array_key_exists('e_time', $data)){ return $this->msg(10001,'关键参数缺失'); } - if($data['acd_id'] == '2'){ - return $this->get_body_record_data($data); - }else if($data['acd_id'] == '6'){ - - } + return $this->get_all_record_data($data); + // if($data['acd_id'] == '2'){ + + // }else if($data['acd_id'] == '6'){ + // $skip = new Skip(); + // return $skip->get_skip_record_data($data); + // } } // 数据对比 @@ -232,26 +240,25 @@ class Card extends Base{ return $this->msg(0,'success',$result_data); } - // 获取身体数据记录信息列表 - function get_body_record_data($data){ + // 获取各类历史数据记录信息列表 + function get_all_record_data($data){ + $result = Db::query(" select id, CONVERT(varchar(10), record_time, 120) AS r_t, CONVERT(varchar(19), record_time, 120) AS record_time, - height, - weight, - bmi - from app_card_body_data + ".$this->db_content[$data['acd_id']]." + from ".$this->db_name[$data['acd_id']]." where aud_id='".$data['aud_id']."' and record_time between '".$data['s_time']."' and '".$data['e_time']."' order by record_time desc"); $return_result = []; foreach ($result as $key => $value) { if(array_key_exists($value['r_t'], $return_result)){ - array_push($return_result[$value['r_t']], ['id'=>$value['id'],'height'=>$value['height'],'weight'=>$value['weight'],'bmi'=>$value['bmi']]); + array_push($return_result[$value['r_t']], ['id'=>$value['id'],'v1'=>$value['v1'],'v2'=>$value['v2'],'v3'=>$value['v3']]); }else{ - $return_result[$value['r_t']] = [['id'=>$value['id'],'height'=>$value['height'],'weight'=>$value['weight'],'bmi'=>$value['bmi']]]; + $return_result[$value['r_t']] = [['id'=>$value['id'],'v1'=>$value['v1'],'v2'=>$value['v2'],'v3'=>$value['v3']]]; } } dump(['original'=>$result,'optimization'=>$return_result]); diff --git a/application/app/controller/Download.php b/application/app/controller/Download.php index cd68c7a..9d313a2 100644 --- a/application/app/controller/Download.php +++ b/application/app/controller/Download.php @@ -7,6 +7,6 @@ use think\Controller; class Download extends Controller{ public function demo(){ - echo '你好'; + echo '你好,这里就是下载页面'; } } \ No newline at end of file diff --git a/application/app/controller/Skip.php b/application/app/controller/Skip.php index 77bb07e..d8e0763 100644 --- a/application/app/controller/Skip.php +++ b/application/app/controller/Skip.php @@ -103,28 +103,76 @@ class Skip extends Base{ } // 运动曲线 - public function skip_motion_curve($data = ['aud_id'=>'','record_time'=>'','type'=>'year']){ - $time_data = ''; - if($data['type'] == 'year'){ - $time_data = date('Y-m',strtotime($data['record_time'])); - }else if($data['type'] == 'month'){ - $time_data = date('Y-m-d',strtotime($data['record_time'])); - }else if($data['type'] == 'day'){ - $time_data = date('Y-m-d H:i:s',strtotime($data['record_time'])); - }else{ - return $this->msg(10001,'type参数错误'); + // public function skip_motion_curve($data = ['aud_id'=>'11','time_data'=>['2024']]){ + public function skip_motion_curve($data = ['aud_id'=>'11','time_data'=>['2024','04']]){ + // public function skip_motion_curve($data = ['aud_id'=>'11','time_data'=>['2024','12','31']]){ + // 确保传入的$data是一个数组且包含所需的键 + if (!is_array($data) || !isset($data['aud_id'], $data['time_data'])) { + return $this->msg(10001,'参数格式错误'); // 返回false或抛出异常 + } + + $audId = $data['aud_id']; + $timeData = $data['time_data']; + + // 根据$timeData的长度构建不同的查询条件 + $map = ['aud_id' => $audId]; + switch (count($timeData)) { + case 3: // 年月日 + $map['record_time'] = ['between', [date('Y-m-d 00:00:00', strtotime($timeData[0] . '-' . $timeData[1] . '-' . $timeData[2])), date('Y-m-d 23:59:59', strtotime($timeData[0] . '-' . $timeData[1] . '-' . $timeData[2]))]]; + break; + case 2: // 年月 + $map['record_time'] = ['between', [date('Y-m-01 00:00:00', strtotime($timeData[0] . '-' . $timeData[1])), date('Y-m-t 23:59:59', strtotime($timeData[0] . '-' . $timeData[1]))]]; + break; + case 1: // 年 + $map['record_time'] = ['between', [date('Y-01-01 00:00:00', strtotime($timeData[0])), date('Y-12-31 23:59:59', strtotime($timeData[0]))]]; + break; + default: + return $this->msg(10002,'时间参数错误'); // 无效的时间数据格式 + } + + // 使用查询构造器进行查询 + $result = Db::name('app_card_skip_data')->where($map)->field('jump_num,jump_time,jump_kcal,aud_id,record_time,jump_type,DATEPART(hour, record_time) AS hour,DATEPART(day, record_time) AS day,DATEPART(month, record_time) AS month')->order('record_time')->select(); + + $return_data = ['jump_num'=>['max'=>0,'list'=>[]],'jump_time'=>['max'=>0,'list'=>[]],'jump_kcal'=>['max'=>0,'list'=>[]]]; + if(count($timeData) == 3){ + $key_condition = 'hour'; + }else if(count($timeData) == 2){ + $key_condition = 'day'; + }else if(count($timeData) == 1){ + $key_condition = 'month'; + } + // dump($result); + // die; + foreach ($result as $key => $value) { + if(!array_key_exists($value[$key_condition], $return_data['jump_num']['list'])){ + $return_data['jump_num']['list'][$value[$key_condition]] = $value['jump_num']; + }else{ + $return_data['jump_num']['list'][$value[$key_condition]] = $return_data['jump_num']['list'][$value[$key_condition]] + $value['jump_num']; + } + if(!array_key_exists($value[$key_condition], $return_data['jump_time']['list'])){ + $return_data['jump_time']['list'][$value[$key_condition]] = $value['jump_time']; + }else{ + $return_data['jump_time']['list'][$value[$key_condition]] = $return_data['jump_time']['list'][$value[$key_condition]] + $value['jump_time']; + } + if(!array_key_exists($value[$key_condition], $return_data['jump_kcal']['list'])){ + $return_data['jump_kcal']['list'][$value[$key_condition]] = $value['jump_kcal']; + }else{ + $return_data['jump_kcal']['list'][$value[$key_condition]] = $return_data['jump_kcal']['list'][$value[$key_condition]] + $value['jump_kcal']; + } } - $user_data = Db::table('app_card_skip_data')->where([ - 'CONVERT(varchar(10), record_time, 120)' => "", - 'jump_num' => $data['num'], - 'jump_time' => $data['time'], - 'jump_kcal' => $data['kcal'], - 'aud_id' => $data['aud_id'], - 'acd_id' => 5, - 'jump_type' => $data['num'] - ]); - dump($user_data); + foreach ($return_data as $key => $value) { + foreach ($value['list'] as $k => $v) { + $return_data[$key]['max'] = $v>$return_data[$key]['max']?$v:$return_data[$key]['max']; + } + } + + return $this->msg(0,'success',$return_data); + + // dump($result); + // dump($return_data); + // die; + // return $result; } @@ -136,30 +184,37 @@ class Skip extends Base{ ################################################################跳绳数据卡片接口################################################################ ################################################################跳绳数据卡片接口################################################################ + public function get_skip_record_data(){} + ################################################################other################################################################ ################################################################other################################################################ ################################################################other################################################################ - // 数据记录 - function generateRandomJumpData($n = 666) { + // 假随机数据插入 + public function generateRandomJumpData($n = 666) { $return_data = []; - $startDate = new \DateTime('2022-01-01 00:00:00'); + $startDate = new \DateTime('2024-01-01 00:00:00'); $endDate = new \DateTime('2024-12-31 23:59:59'); // 为了保证在$startDate和$endDate之间随机生成日期,先确定两个日期之间的天数差 $diff = $endDate->diff($startDate)->format('%a'); + + $startTime = strtotime('2024-01-01 00:00:00'); + $endTime = strtotime('2024-12-31 23:59:59'); + + for ($i = 0; $i < $n; $i++) { // 生成随机日期 - $randomDateTime = $startDate->modify(sprintf('+%d seconds', rand(0, $endDate->getTimestamp() - $startDate->getTimestamp())))->format('Y-m-d H:i:s'); - // $randomDate = $startDate->modify(sprintf('+%d days', rand(0, $diff)))->format('Y-m-d'); + $randomSeconds = random_int($startTime, $endTime); + $randomDateTime = date('Y-m-d H:i:s', $randomSeconds); // 生成随机jump_num $jump_num = rand(30, 70); // 生成随机jump_time - $jump_time = rand(60, 200); + $jump_time = rand(60, 150); // 生成随机jump_kcal $jump_kcal = rand(100, 400); @@ -184,12 +239,23 @@ class Skip extends Base{ 'jump_type' => $jump_type ]; } + // dump($return_data); + // die; $user_data = Db::table('app_card_skip_data')->insertAll($return_data); dump($user_data); dump($return_data); die; } + // 设置数据库 + public function setdb($n = 666) { + + $num = [1,1]; + + for ($i=0; $i < 10; $i++) { + $num; + } + } diff --git a/application/config.php b/application/config.php index 85f09a0..53fc153 100644 --- a/application/config.php +++ b/application/config.php @@ -87,7 +87,7 @@ return [ // URL参数方式 0 按名称成对解析 1 按顺序解析 'url_param_type' => 0, // 是否开启路由 - 'url_route_on' => false, + 'url_route_on' => true, // 路由使用完整匹配 'route_complete_match' => false, // 路由配置文件(支持配置多个) diff --git a/application/route.php b/application/route.php index 9e54275..3c460df 100644 --- a/application/route.php +++ b/application/route.php @@ -34,6 +34,44 @@ Route::get('/download', 'app/download/demo'); // // ################################################################APP接口################################################################ // // ################################################################APP接口################################################################ +// ################################身体接口################################ +// 查找设备 +Route::any('/get_card_record_data', 'app/card/get_card_record_data'); +// // 今日数据 +// Route::any('/skip_today_data', 'app/skip/skip_today_data'); +// // 数据记录 +// Route::any('/skip_record_data', 'app/skip/skip_record_data'); +// // 运动曲线 +// Route::any('/skip_motion_curve', 'app/skip/skip_motion_curve'); +// Route::any('/generateRandomJumpData', 'app/skip/generateRandomJumpData'); +// ################################跳绳接口################################ +// 查找设备 +Route::any('/skip_device_check', 'app/skip/skip_device_check'); +// 今日数据 +Route::any('/skip_today_data', 'app/skip/skip_today_data'); +// 数据记录 +Route::any('/skip_record_data', 'app/skip/skip_record_data'); +// 运动曲线 +Route::any('/skip_motion_curve', 'app/skip/skip_motion_curve'); +Route::any('/generateRandomJumpData', 'app/skip/generateRandomJumpData'); + + +// Route::any('/skip_device_check', 'app/skip/skip_device_check'); +// Route::any('/skip_device_check', 'app/skip/skip_device_check'); +// Route::any('/skip_device_check', 'app/skip/skip_device_check'); +// Route::any('/skip_device_check', 'app/skip/skip_device_check'); +// Route::any('/skip_device_check', 'app/skip/skip_device_check'); +// Route::any('/skip_device_check', 'app/skip/skip_device_check'); +// Route::any('/skip_device_check', 'app/skip/skip_device_check'); +// Route::any('/skip_device_check', 'app/skip/skip_device_check'); +// Route::any('/skip_device_check', 'app/skip/skip_device_check'); +// Route::any('/skip_device_check', 'app/skip/skip_device_check'); +// Route::any('/skip_device_check', 'app/skip/skip_device_check'); + +// // ################################################################其它测试################################################################ +// // ################################################################其它测试################################################################ +Route::any('/generateRandomJumpData', 'app/skip/generateRandomJumpData'); +Route::any('/setdb', 'app/skip/setdb'); // 处理404错误 z Route::miss(function(){