123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420 |
- <?php
- namespace catchAdmin\api\controller;
- use catchAdmin\api\service\dispose;
- use catchAdmin\tag_history\model\Access;
- use catchAdmin\tag_history\model\Dormitory;
- use catchAdmin\tag_history\model\TagHistory;
- use catchAdmin\worklocation\model\WorkRecord as ModelWorkRecord;
- use catcher\base\CatchRequest as Request;
- use catcher\CatchResponse;
- use catcher\base\CatchController;
- use Exception;
- use think\facade\Cache;
- use \think\facade\Db;
- error_reporting(0);
- class Api extends CatchController
- {
- public function report()
- {
- $token = $_GET['token'];
- if (!$token || $token != '22723927C') {
- json_fail('缺少token或者token不对');
- }
- $param = json_decode(optimize_json(file_get_contents("php://input")), true);
- debug_log("上报数据",json_encode($param));
- if (json_last_error() != 0) {
- json_fail('解析异常', json_last_error_msg());
- }
- $mac = $param['mac'];
- if (empty($mac)) {
- json_fail('mac地址不存在');
- }
- $data = [];
- foreach ($param['list'] as $item) {
- // $onetime= TagHistory::where("mac",$mac)->where('lable',$item['label'])->order("id","desc")->value("time");
- $data[] = [
- 'mac' => $mac,
- 'lable' => $item['label'],
- 'rssi' => $item['rssi'],
- 'time' => $item['time'],
- 'addTime' => time(),
- 'move' => $item['move'],
- 'step' => empty($item['step']) ? 0 : $item['step'],
- 'temperature' => empty($item['temperature']) ? 0 : $item['temperature'],
- //告警
- 'temperWarn' => empty($item['temperWarn']) ? 00 : $item['temperWarn'],
- // "interval_time"=>empty($onetime) ?0:($item['time']-$onetime)
- ];
- }
- $tage = new TagHistory();
- $tage->saveAll($data);
- json_success('上传成功');
- }
- //储存数据到redis
- public function redis_to_mysql(){
-
- $ues_redis=Cache::store('redis')->handler();
- $text=null;
-
- while(1){
- $jsonData= $ues_redis->rpop("mqtt_data");
- debug_log("InAndOUT",'数据redis'.$jsonData);
-
- if(empty($jsonData)){
- debug_log("InAndOUT",'没有数据');
- sleep(1);
- continue;
-
- }
- // debug_log("InAndOUT",$jsonData);
- $data=json_decode($jsonData,true);
- // debug_log("InAndOUT",$data['cnt']);
- $time=$data['time'];
- $mac=$data['imei'];
- $list=[];
- $text=$text.$data['cnt'];
-
- if(strlen($text)<24){
- continue;
- }
- while(strlen($text)>=24){
-
- $da=substr($text,0,24);
- $t1 = substr($da,8,2)=='00'||substr($da,8,2)=='10'||substr($da,8,2)=='01' ? true:false;
- $t2 =substr($da,10,6)=="FFFFFF"||substr($da,10,6)=="000000" ?true:false;
-
- if($t1&&$t2){
-
- $label= substr($da,0,8);
- $rssi1= substr($da,16,2);
- $rssi2= substr($da,18,2);
- $rssi3= substr($da,20,2);
- $rssi4= substr($da,22,2);
- $DA=[
- 'mac' => $mac,
- 'label' =>$label,
- 'rssi1' => hexdec($rssi1),
- 'rssi2' => hexdec($rssi2),
- 'rssi3' => hexdec($rssi3),
- 'rssi4' => hexdec($rssi4),
- 'report_time'=>$time
- ];
- debug_log("InAndOUT","数据:".json_encode($DA,true));
- //保存计算中
- //分为8个桶
- // $num=Hexdec($label);
- // $Identification=$num%8;
- // $key="buckets".$Identification;
- // $ues_redis->rPush($key,json_encode($DA,true));
-
- try{
- $dispose = new dispose($ues_redis);
- $computedata=$dispose->computeData($DA);
- debug_log("InAndOUT","计算完成的数据:".json_encode($DA,true));
- $dispose->computeResout($computedata);
-
- }catch(Exception $e){
- debug_log("InAndOUT","抛出异常".json_encode($DA,true));
- }
-
- $text=substr($text,24);
- }else{
- $text=substr($text,1);
- }
-
- }
-
- // $tage = new Access();
- // $tage->saveAll($list);
- }
- }
- public function redis_to_mysql_parea(){
- $ues_redis=Cache::store('redis')->handler();
- $text="";
- $dispose = new dispose($ues_redis);
- while(1){
- $jsonData= $ues_redis->rpop("mqtt_data_parea4rssi");
- debug_log("InAndOUT",'数据redis'.$jsonData);
-
- if(empty($jsonData)){
- debug_log("InAndOUT",'没有数据');
- sleep(1);
- continue;
-
- }
- // debug_log("InAndOUT",$jsonData);
- $data=json_decode($jsonData,true);
- // debug_log("InAndOUT",$data['cnt']);
- $time=$data['time'];
- $mac=$data['mac'];
- $text=$text.$data['cnt'];
-
- if(strlen($text)<24){
- continue;
- }
- $text = $this->handleMessage($text, $mac, $time, $ues_redis);
- // foreach ($jsonData as $k => $v) {
- // $data = json_decode($v, true);
- // $config = $this->selectHash("anbang_four_wire",$data['mac']);
- // if(!$config){
- // $config = [
- // "front" => 70,
- // "behind" => 70,
- // "left" => 70,
- // "right" => 70
- // ];
- // }else{
- // $config = json_decode($config);
- // }
- // $field = "";
- // $infos = $ues_redis->hget("parea_rfidinfos",$field);
- // if(!$infos){
-
- // }
- // //判断进出段
- // //1。当前时间 - 上次时间 > 设定时间
- // if( (time() - $v["time"]) > $setInt ){
- // //推送离开
- // }
- // }
- sleep(2);
- }
- }
- // //http://47.114.185.186:8115/api/areaReport
- // //{“mac”:”013560”,”data”:[{“label”:”258962f”,”time”:1682317268,”dirt”:2},{“label”:”258962f”,”time”:1682317268,”dirt”:1}]
- // }
- //消息处理
- public function handleMessage($text, $mac, $time, $ues_redis){
- while(strlen($text)>=24){
-
- $da=substr($text,0,24);
- $t1 = substr($da,8,2)=='00'||substr($da,8,2)=='10'||substr($da,8,2)=='01' ? true:false;
- $t2 =substr($da,10,6)=="FFFFFF"||substr($da,10,6)=="000000" ?true:false;
-
- if($t1&&$t2){
- // var_dump($text);
- $rfid= substr($da,0,8);
- $rssi1= hexdec(substr($da,16,2));
- $rssi2= hexdec(substr($da,18,2));
- $rssi3= hexdec(substr($da,20,2));
- $rssi4= hexdec(substr($da,22,2));
- // $rc1 = ($rssi1 == 255 ? 0 : 1);
- // $rc2 = ($rssi2 == 255 ? 0 : 1);
- // $rc3 = ($rssi3 == 255 ? 0 : 1);
- // $rc4 = ($rssi4 == 255 ? 0 : 1);
- $DA=[
- 'mac' => $mac,
- 'label' =>$rfid,
- 'rssi1' => $rssi1,
- 'rssi2' => $rssi2,
- 'rssi3' => $rssi3,
- 'rssi4' => $rssi4,
- 'report_time'=>$time
- ];
-
- $field = $mac."_".$rfid;
- $info = $ues_redis->hget("parea_rfidinfos",$field);
- debug_log("InAndOUT","数据:".json_encode($DA,true));
- if(!$info){
- $info = [
- "mac" => $mac,
- "id" => $rfid,
- "firs_time" => $time,
- "last_time" => $time,
- "status" => 1,//1出状态,2进状态
- "rssi" => [
- [
- "front" => $rssi1,
- "behind" => $rssi2,
- "left" => $rssi3,
- "right" => $rssi4,
- "time" => $time
- ]
- ]
- ];
- $ues_redis->hset("parea_rfidinfos",$field, json_encode($info,true));
- }else{
- $info = json_decode($info,true);
- $info["last_time"] = $time;
- $newRssi = [
- "front" => $rssi1,
- "behind" => $rssi2,
- "left" => $rssi3,
- "right" => $rssi4,
- "time" => $time
- ];
- $rssisArr = $info["rssi"];
- foreach ($rssisArr as $k => $v) {
- # code...
- if( ($time - $v["time"] ) > $EXP_TIME ){
- unset($rssisArr[$k]);
- }
- }
- if(count($rssisArr) == $EFF_SIG_NUM){
- array_shift($rssisArr);
- array_push($rssisArr, $newRssi);
- }else{
- array_push($rssisArr, $newRssi);
- }
- $info["rssi"] = $rssisArr;
- $cacCount = count($rssisArr);
- // if($cacCount > $EFF_SIG_NUM){
- $sum1 = 0;
- $sum2 = 0;
- $sum3 = 0;
- $sum4 = 0;
- foreach ($rssisArr as $k => $v) {
- # code...
- $sum1 += ($v["front"] == 255 ? 85 : $v["front"]);
- $sum2 += ($v["behind"] == 255 ? 85 : $v["behind"]);
- $sum3 += ($v["left"] == 255 ? 85 : $v["left"]);
- $sum4 += ($v["right"] == 255 ? 85 : $v["right"]);
- }
- $info["avg"] = [
- "front" => number_format( $sum1/$cacCount, 2 ),
- "behind" => number_format( $sum2/$cacCount, 2 ),
- "left" => number_format( $sum3/$cacCount, 2 ),
- "right" => number_format( $sum4/$cacCount, 2 ),
- ];
- if ($cacCount == $EFF_SIG_NUM) {
- # code...
- $this->compAndPush($info["avg"], $mac, $rfid, $ues_redis);
- }
- $ues_redis->hset("parea_rfidinfos",$field, json_encode($info,true));
- }
- $text=substr($text,24);
- }else{
- $text=substr($text,1);
- }
- }
- return $text ?$text : "";
- }
- //判断进出和推送
- public function compAndPush($data, $mac, $rfid, $ues_redis){
- //标签多,数据多时候,判断完成后放入redis,异步推送,当前暂时直接推
- if (empty($data)) {
- # code...
- return false;
- }
- $config = $ues_redis->hget("anbang_four_wire", $mac);
- //{"front_in":44,"front_out":44,"behind_in":50,"behind_out":50,"left_in":55,"left_out":55,"right_out":44,"right_out":44}
- if (!$config) {
- # code...
- $config = [
- "front_in" => 70,
- "behind_in" => 70,
- "left_in" => 70,
- "right_in" => 70,
- "front_out" => 80,
- "behind_out" => 80,
- "left_out" => 80,
- "right_out" => 80,
- ];
- }
- $flagIn = $data["front"] < $config["front_in"] || $data["behind"] < $config["behind_in"] || $data["left"] < $config["left_in"] || $data["right"] < $config["right_in"];
- $flagOut = $data["front"] > $config["front_out"] && $data["behind"] < $config["behind_out"] && $data["left"] < $config["left_out"] && $data["right"] < $config["right_out"];
- if($flagIn){
- //推送进
- }else{
- //推送出
- }
- return true;
- }
-
- public function test(){
-
- try{
- $ues_redis=Cache::store('redis')->handler();
- $jsonData= $ues_redis->rpop("mqtt_data");
- debug_log("InAndOUT","1212");
- }catch(Exception $e){
- var_dump($e->getMessage());
- }
-
- }
- /**
- * 删除前1天的数据
- *
- * @return void
- */
- public function deleteHistory()
- {
- while(true)
- {
-
- $where[] = ['addTime','<',strtotime("-1 day")];
- Db::name('tag_history')->where($where)->delete();
- sleep(60*60*24);
- }
-
- }
-
- /**
- * 检测小程序版本版本 function
- *
- * @return void
- */
- public function detectionVersion(){
- $token = $_GET['token'];
- if (!$token || $token != '444333d3') {
- json_fail('缺少token或者token不对');
- }
- $data["url"]="http://116.62.220.88:8112/static/app/蓝牙小程序/1.1.1/rl-release.apk";
- $data["version"]="1.1.1";
- json_success("查询版本成功",$data);
- }
-
- }
|