Api.php 18 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518
  1. <?php
  2. namespace catchAdmin\api\controller;
  3. use catchAdmin\api\service\dispose;
  4. use catchAdmin\tag_history\model\Access;
  5. use catchAdmin\tag_history\model\Dormitory;
  6. use catchAdmin\tag_history\model\TagHistory;
  7. use catchAdmin\worklocation\model\WorkRecord as ModelWorkRecord;
  8. use catcher\base\CatchRequest as Request;
  9. use catcher\CatchResponse;
  10. use catcher\base\CatchController;
  11. use Exception;
  12. use think\facade\Cache;
  13. use \think\facade\Db;
  14. error_reporting(0);
  15. class Api extends CatchController
  16. {
  17. public function report()
  18. {
  19. $token = $_GET['token'];
  20. if (!$token || $token != '22723927C') {
  21. json_fail('缺少token或者token不对');
  22. }
  23. $param = json_decode(optimize_json(file_get_contents("php://input")), true);
  24. debug_log("上报数据",json_encode($param));
  25. if (json_last_error() != 0) {
  26. json_fail('解析异常', json_last_error_msg());
  27. }
  28. $mac = $param['mac'];
  29. if (empty($mac)) {
  30. json_fail('mac地址不存在');
  31. }
  32. $data = [];
  33. foreach ($param['list'] as $item) {
  34. // $onetime= TagHistory::where("mac",$mac)->where('lable',$item['label'])->order("id","desc")->value("time");
  35. $data[] = [
  36. 'mac' => $mac,
  37. 'lable' => $item['label'],
  38. 'rssi' => $item['rssi'],
  39. 'time' => $item['time'],
  40. 'addTime' => time(),
  41. 'move' => $item['move'],
  42. 'step' => empty($item['step']) ? 0 : $item['step'],
  43. 'temperature' => empty($item['temperature']) ? 0 : $item['temperature'],
  44. //告警
  45. 'temperWarn' => empty($item['temperWarn']) ? 00 : $item['temperWarn'],
  46. // "interval_time"=>empty($onetime) ?0:($item['time']-$onetime)
  47. ];
  48. }
  49. $tage = new TagHistory();
  50. $tage->saveAll($data);
  51. json_success('上传成功');
  52. }
  53. //储存数据到redis
  54. public function redis_to_mysql(){
  55. $ues_redis=Cache::store('redis')->handler();
  56. $text=null;
  57. $testArray=[
  58. '884619516',
  59. '885907612',
  60. '3827256674',
  61. '885833308',
  62. '884019740',
  63. '884765612'
  64. ];
  65. while(1){
  66. $jsonData= $ues_redis->rpop("mqtt_data");
  67. debug_log("InAndOUT",'数据redis'.$jsonData);
  68. if(empty($jsonData)){
  69. debug_log("InAndOUT",'没有数据');
  70. sleep(1);
  71. continue;
  72. }
  73. // debug_log("InAndOUT",$jsonData);
  74. $data=json_decode($jsonData,true);
  75. // debug_log("InAndOUT",$data['cnt']);
  76. $time=$data['time'];
  77. $mac=$data['imei'];
  78. $list=[];
  79. $text=$text.$data['cnt'];
  80. if(strlen($text)<24){
  81. continue;
  82. }
  83. // $arr=['']
  84. while(strlen($text)>=24){
  85. $da=substr($text,0,24);
  86. $t1 = substr($da,8,2)=='00'||substr($da,8,2)=='10'||substr($da,8,2)=='01' ? true:false;
  87. $t2 =substr($da,10,6)=="FFFFFF"||substr($da,10,6)=="000000" ?true:false;
  88. if($t1&&$t2){
  89. $label= substr($da,0,8);
  90. $rssi1= substr($da,16,2);
  91. $rssi2= substr($da,18,2);
  92. $rssi3= substr($da,20,2);
  93. $rssi4= substr($da,22,2);
  94. $DA=[
  95. 'mac' => $mac,
  96. 'label' =>$label,
  97. 'rssi1' => hexdec($rssi2),
  98. 'rssi2' => hexdec($rssi3),
  99. 'rssi3' => hexdec($rssi1),
  100. 'rssi4' => hexdec($rssi4),
  101. 'report_time'=>$time
  102. ];
  103. // if($DA['rssi1']==255){
  104. // $DA['rssi1']=100;
  105. // }
  106. // if($DA['rssi2']==255){
  107. // $DA['rssi2']=100;
  108. // }
  109. // debug_log("InAndOUT","数据:".json_encode($DA,true));
  110. //保存计算中
  111. //分为8个桶
  112. // $num=Hexdec($label);
  113. // $Identification=$num%8;
  114. // $key="buckets".$Identification;
  115. // $ues_redis->rPush($key,json_encode($DA,true));
  116. $num=Hexdec($label);
  117. $vs=false;
  118. if($DA['rssi1']<255&&$DA['rssi2']<255){
  119. $vs=true;
  120. }
  121. if(in_array($num,$testArray)&&$vs&&(substr($da,8,2)=='01')){
  122. $testData=$DA;
  123. $testData['num']=$num;
  124. debug_log("label_log",json_encode($testData));
  125. debug_log('label_log',$da);
  126. try{
  127. $dispose = new dispose($ues_redis);
  128. $computedata=$dispose->computeData($DA);
  129. //debug_log("InAndOUT","计算完成的数据:".json_encode($computedata,true));
  130. $dispose->computeResout($computedata);
  131. }catch(Exception $e){
  132. debug_log("InAndOUT","抛出异常".json_encode($DA,true));
  133. }
  134. }
  135. $text=substr($text,24);
  136. }else{
  137. $text=substr($text,1);
  138. }
  139. }
  140. // $tage = new Access();
  141. // $tage->saveAll($list);
  142. }
  143. }
  144. public function redis_to_mysql_parea(){
  145. $ues_redis=Cache::store('redis')->handler();
  146. $text="";
  147. $dispose = new dispose($ues_redis);
  148. while(1){
  149. $jsonData= $ues_redis->rpop("mqtt_data_parea4rssi");
  150. debug_log("pare_InAndOUT",'数据redis'.$jsonData);
  151. if(empty($jsonData)){
  152. debug_log("pare_InAndOUT",'没有数据');
  153. sleep(1);
  154. continue;
  155. }
  156. // debug_log("InAndOUT",$jsonData);
  157. $data=json_decode($jsonData,true);
  158. // debug_log("InAndOUT",$data['cnt']);
  159. $time=$data['time'];
  160. $mac=$data['devId'];
  161. $text=$text.$data['cnt'];
  162. if(strlen($text)<24){
  163. continue;
  164. }
  165. $text = $this->handleMessage($text, $mac, $time, $ues_redis);
  166. // foreach ($jsonData as $k => $v) {
  167. // $data = json_decode($v, true);
  168. // $config = $this->selectHash("anbang_four_wire",$data['mac']);
  169. // if(!$config){
  170. // $config = [
  171. // "front" => 70,
  172. // "behind" => 70,
  173. // "left" => 70,
  174. // "right" => 70
  175. // ];
  176. // }else{
  177. // $config = json_decode($config);
  178. // }
  179. // $field = "";
  180. // $infos = $ues_redis->hget("parea_rfidinfos",$field);
  181. // if(!$infos){
  182. // }
  183. // //判断进出段
  184. // //1。当前时间 - 上次时间 > 设定时间
  185. // if( (time() - $v["time"]) > $setInt ){
  186. // //推送离开
  187. // }
  188. // }
  189. // sleep(2);
  190. }
  191. }
  192. // //http://47.114.185.186:8115/api/areaReport
  193. // //{“mac”:”013560”,”data”:[{“label”:”258962f”,”time”:1682317268,”dirt”:2},{“label”:”258962f”,”time”:1682317268,”dirt”:1}]
  194. // }
  195. //消息处理
  196. public function handleMessage($text, $mac, $time, $ues_redis){
  197. $EXP_TIME = 20;
  198. $EFF_SIG_NUM = 10;
  199. while(strlen($text)>=24){
  200. $da=substr($text,0,24);
  201. $t1 = substr($da,8,2)=='00'||substr($da,8,2)=='10'||substr($da,8,2)=='01' ? true:false;
  202. $t2 =substr($da,10,6)=="FFFFFF"||substr($da,10,6)=="000000" ?true:false;
  203. if($t1&&$t2){
  204. // var_dump($text);
  205. $rfid= substr($da,0,8);
  206. $rssi1= hexdec(substr($da,16,2));
  207. $rssi2= hexdec(substr($da,18,2));
  208. $rssi3= hexdec(substr($da,20,2));
  209. $rssi4= hexdec(substr($da,22,2));
  210. // $rc1 = ($rssi1 == 255 ? 0 : 1);
  211. // $rc2 = ($rssi2 == 255 ? 0 : 1);
  212. // $rc3 = ($rssi3 == 255 ? 0 : 1);
  213. // $rc4 = ($rssi4 == 255 ? 0 : 1);
  214. $DA=[
  215. 'mac' => $mac,
  216. 'label' =>$rfid,
  217. 'rssi1' => $rssi1,
  218. 'rssi2' => $rssi2,
  219. 'rssi3' => $rssi3,
  220. 'rssi4' => $rssi4,
  221. 'report_time'=>$time
  222. ];
  223. $field = $mac."_".$rfid;
  224. $info = $ues_redis->hget("parea_rfidinfos",$field);
  225. debug_log("pare_InAndOUT","数据:".json_encode($DA,true));
  226. if($rssi1 ==255 && $rssi2 == 255 && $rssi3 == 255 && $rssi4 == 255){
  227. debug_log("pare_InAndOUT","无效数据:".json_encode($DA,true));
  228. }else{
  229. if(!$info){
  230. $info = [
  231. "mac" => $mac,
  232. "id" => $rfid,
  233. "firs_time" => $time,
  234. "time" => $time,
  235. "status" => 2,//2出状态,1进状态
  236. "rssi" => [
  237. [
  238. "front" => $rssi1,
  239. "behind" => $rssi2,
  240. "left" => $rssi3,
  241. "right" => $rssi4,
  242. "time" => $time
  243. ]
  244. ]
  245. ];
  246. $ues_redis->hset("parea_rfidinfos",$field, json_encode($info,true));
  247. debug_log("parea_rfidinfos_redis_set_record","redis更新记录".json_encode($info,true));
  248. }else{
  249. $info = json_decode($info,true);
  250. $config = $ues_redis->hget("anbang_four_wire", $info["mac"]);
  251. if (!$config) {
  252. # code...
  253. $config = [
  254. "front_in" => 65,
  255. "behind_in" => 70,
  256. "left_in" => 80,
  257. "right_in" => 70,
  258. "front_out" => 70,
  259. "behind_out" => 75,
  260. "left_out" => 82,
  261. "right_out" => 70,
  262. "expInt" => 20,
  263. "effSigNum" => 10
  264. ];
  265. }else{
  266. $config = json_decode($config,true);
  267. }
  268. // var_dump("+++++++++++++++++",$config);
  269. $info["time"] = $time;
  270. $newRssi = [
  271. "front" => $rssi1,
  272. "behind" => $rssi2,
  273. "left" => $rssi3,
  274. "right" => $rssi4,
  275. "time" => $time
  276. ];
  277. $rssisArr = $info["rssi"];
  278. // var_dump("+++++++++++++++++", $time, $newRssi["time"]);
  279. foreach ($rssisArr as $k => $v) {
  280. # code...
  281. if( ($time - $v["time"] ) > $config['expInt'] ){
  282. unset($rssisArr[$k]);
  283. }
  284. }
  285. // var_dump("+++++++++++++++++",$rssisArr);
  286. if(count($rssisArr) == $config['effSigNum']){
  287. array_shift($rssisArr);
  288. array_push($rssisArr, $newRssi);
  289. }else{
  290. array_push($rssisArr, $newRssi);
  291. }
  292. $rssisArr =array_values($rssisArr);
  293. // var_dump("+++++++++++++++++",$rssisArr);
  294. $info["rssi"] = $rssisArr;
  295. // var_dump("------------",$info["rssi"]);
  296. $cacCount = count($rssisArr);
  297. // if($cacCount > $EFF_SIG_NUM){
  298. $sum1 = 0;
  299. $sum2 = 0;
  300. $sum3 = 0;
  301. $sum4 = 0;
  302. foreach ($rssisArr as $k => $v) {
  303. # code...
  304. $sum1 += ($v["front"] == 255 ? 85 : $v["front"]);
  305. $sum2 += ($v["behind"] == 255 ? 85 : $v["behind"]);
  306. $sum3 += ($v["left"] == 255 ? 85 : $v["left"]);
  307. $sum4 += ($v["right"] == 255 ? 85 : $v["right"]);
  308. }
  309. $info["avg"] = [
  310. "front" => number_format( $sum1/$cacCount, 2 ),
  311. "behind" => number_format( $sum2/$cacCount, 2 ),
  312. "left" => number_format( $sum3/$cacCount, 2 ),
  313. "right" => number_format( $sum4/$cacCount, 2 ),
  314. ];
  315. if ($cacCount == $EFF_SIG_NUM) {
  316. # code...
  317. $info = $this->compAndPush($info ,$config);
  318. }
  319. $ues_redis->hset("parea_rfidinfos",$field, json_encode($info,true));
  320. debug_log("parea_rfidinfos_redis_set_record","redis更新记录".json_encode($info,true));
  321. }
  322. }
  323. $text=substr($text,24);
  324. }else{
  325. $text=substr($text,1);
  326. }
  327. }
  328. return $text ?$text : "";
  329. }
  330. //判断进出和推送
  331. public function compAndPush($info, $config ){
  332. //标签多,数据多时候,判断完成后放入redis,异步推送,当前暂时直接推
  333. // $config = $ues_redis->hget("anbang_four_wire", $info["mac"]);
  334. //{"front_in":44,"front_out":44,"behind_in":50,"behind_out":50,"left_in":55,"left_out":55,"right_out":44,"right_out":44}
  335. $avg = $info['avg'];
  336. $status = $info['status'];
  337. $flagIn = $avg["front"] < $config["front_in"] || $avg["behind"] < $config["behind_in"] || $avg["left"] < $config["left_in"] || $avg["right"] < $config["right_in"];
  338. $flagOut = $avg["front"] > $config["front_out"] && $avg["behind"] > $config["behind_out"] && $avg["left"] > $config["left_out"] && $avg["right"] > $config["right_out"];
  339. $url="http://47.114.185.186:8115/api/areaReport";
  340. if($flagIn && $status == 2){
  341. //推送进
  342. $info['status'] = 1;
  343. $url_data = [
  344. "mac" => $info["mac"],
  345. "data" => [
  346. [
  347. "label" => $info["id"],
  348. "time" => $info["time"],
  349. "dirt" => 1
  350. ]
  351. ]
  352. ];
  353. debug_log("pushPareaRes","进推送依赖:".json_encode($info));
  354. $url_res= curl_http_post(json_encode($url_data),$url,false);
  355. debug_log("pushPareaRes","远程返回结果".$url_res);
  356. }
  357. // if($info['id'] == "E2B15AD5"){
  358. // var_dump($flagIn, $flagOut, $status, $avg["front"],$avg["behind"],$avg["left"], $avg["right"]);
  359. // }
  360. if($flagOut && $status == 1){
  361. //推送出
  362. $info['status'] = 2;
  363. $url_data = [
  364. "mac" => $info["mac"],
  365. "data" => [
  366. [
  367. "label" => $info["id"],
  368. "time" => $info["time"],
  369. "dirt" => 2
  370. ]
  371. ]
  372. ];
  373. debug_log("pushPareaRes","出推送依赖:".json_encode($info));
  374. $url_res= curl_http_post(json_encode($url_data),$url,false);
  375. debug_log("pushPareaRes","远程返回结果".$url_res);
  376. }
  377. return $info;
  378. }
  379. // $url="http://47.114.185.186:8115/api/accessReport";
  380. // $url_res= curl_http_post(json_encode($url_data),$url,false);
  381. // debug_log("InAndOUT","远程返回结果".$url_res);
  382. public function test(){
  383. try{
  384. $ues_redis=Cache::store('redis')->handler();
  385. $jsonData= $ues_redis->rpop("mqtt_data");
  386. debug_log("InAndOUT","1212");
  387. }catch(Exception $e){
  388. var_dump($e->getMessage());
  389. }
  390. }
  391. /**
  392. * 删除前1天的数据
  393. *
  394. * @return void
  395. */
  396. public function deleteHistory()
  397. {
  398. while(true)
  399. {
  400. $where[] = ['addTime','<',strtotime("-1 day")];
  401. Db::name('tag_history')->where($where)->delete();
  402. sleep(60*60*24);
  403. }
  404. }
  405. /**
  406. * 检测小程序版本版本 function
  407. *
  408. * @return void
  409. */
  410. public function detectionVersion(){
  411. $token = $_GET['token'];
  412. if (!$token || $token != '444333d3') {
  413. json_fail('缺少token或者token不对');
  414. }
  415. $data["url"]="http://116.62.220.88:8112/static/app/蓝牙小程序/1.1.1/rl-release.apk";
  416. $data["version"]="1.1.1";
  417. json_success("查询版本成功",$data);
  418. }
  419. }