Order.php.bak4 61 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132
  1. <?php
  2. namespace app\admin\controller;
  3. use think\Controller;
  4. use think\Session;
  5. use think\Db;
  6. use think\Request;
  7. use think\Log;
  8. class Order extends Controller
  9. {
  10. private $host="https://device.api.ct10649.com:8743/";
  11. private $appId="wvdOfp7JVe0ULwnFKwBF0edfbcAa";
  12. private $secret="Bihoe_rY9vebXMw6sFfpQy0jiRca";
  13. public function index(){
  14. $data_list =Db::name('order')->paginate();
  15. $pages = $data_list->render();
  16. $this->assign('data_list', $data_list);
  17. $this->assign('pages', $pages);
  18. return $this->fetch();
  19. }
  20. public function add(){
  21. $res=Db::name('order')->where('notifyType',input('notifyType'))->find();
  22. if(!$res){
  23. if ($this->request->isPost()) {
  24. $data=$_POST;
  25. //验证数据
  26. if(empty($data['notifyType'])||empty($data['callbackUrl'])){
  27. return $this->error("请填写好必要内容");
  28. }
  29. $token=json_decode(gettoken(),true);
  30. $sendata=[
  31. "notifyType"=>$data['notifyType'],
  32. "callbackUrl"=>$data['callbackUrl'],
  33. "appId"=>$this->appId,
  34. ];
  35. $header=[
  36. "Content-Type:application/json",
  37. "app_key:".$this->appId,
  38. "Authorization:Bearer ".$token["accessToken"]
  39. ];
  40. //https://server:port/iocm/app/sub/v1.2.0/subscriptions?ownerFlag={ownerFlag}
  41. $rescurl=curl($this->host."iocm/app/sub/v1.2.0/subscriptions",json_encode($sendata),$header);
  42. dump($rescurl);
  43. if($rescurl[0]==201){//成功
  44. $res1=json_decode($rescurl[1],true);
  45. }else{//失败
  46. // $res2=json_decode($res1[1],true);
  47. return $this->error($rescurl[1]);
  48. }
  49. //添加
  50. $list=array();
  51. $list['notifyType']= $data['notifyType'];
  52. $list['callbackUrl']= $data['callbackUrl'];
  53. $list['subscriptionId']= $res1['subscriptionId'];
  54. $list['addtime']= date('Y-m-d H:i:s');
  55. $list['updatetime']= date('Y-m-d H:i:s');
  56. $res = Db::name('order')->insertGetId($list);
  57. if($res) {
  58. return $this->success('添加成功','index');
  59. }else{
  60. return $this->error("添加失败,请稍后再试");
  61. }
  62. }
  63. }else{
  64. return $this->error("该订阅类型已经填写");
  65. }
  66. $notifyType=Db::table('notifyType')->select();
  67. $this->assign('notifyType', $notifyType);
  68. return $this->fetch();
  69. }
  70. /* public function edit(){
  71. if ($this->request->isPost()) {
  72. $data=$_POST;
  73. //验证数据
  74. if(empty($data['callbackUrl'])){
  75. return $this->error("请填写好必要内容");
  76. }
  77. $token=json_decode(gettoken(),true);
  78. $sendata=[
  79. "notifyType"=>$data['notifyType'],
  80. "callbackUrl"=>$data['callbackUrl'],
  81. "appId"=>$this->appId,
  82. ];
  83. $header=[
  84. "Content-Type:application/json",
  85. "app_key:".$this->appId,
  86. "Authorization:Bearer ".$token["accessToken"]
  87. ];
  88. //https://server:port/iocm/app/sub/v1.2.0/subscriptions?ownerFlag={ownerFlag}
  89. $res1=curl($this->host."iocm/app/sub/v1.2.0/subscriptions",json_encode($sendata),$header);
  90. $res1=json_decode($res1,true);
  91. $list=array();
  92. $list['notifyType']= $data['notifyType'];
  93. $list['callbackUrl']= $data['callbackUrl'];
  94. $list['subscriptionId']= $res1['subscriptionId'];
  95. $list['updatetime']= date('Y-m-d H:i:s');
  96. $res = Db::name('order')->where('id',$data['id'])->update($list);
  97. if($res) {
  98. return $this->success('编辑成功','index');
  99. }else{
  100. return $this->error("编辑失败,请稍后再试");
  101. }
  102. }
  103. $notifyType=Db::table('notifyType')->select();
  104. $this->assign('notifyType', $notifyType);
  105. $res=Db::name('order')->where('id',input('id'))->find();
  106. $this->assign('data', $res);
  107. return $this->fetch();
  108. }*/
  109. //删除订阅
  110. public function delete(){
  111. if ($this->request->isPost()) {
  112. $data=$_POST;
  113. $token=json_decode(gettoken(),true);
  114. $header=[
  115. "Content-Type:application/json",
  116. "app_key:".$this->appId,
  117. "Authorization:Bearer ".$token["accessToken"]
  118. ];
  119. //https://server:port/iocm/app/sub/v1.2.0/subscriptions/{subscriptionId}
  120. $rescurl=curl($this->host."iocm/app/sub/v1.2.0/subscriptions/".$data['subscriptionId'],"",$header,"DELETE");
  121. if($rescurl[0]==204){//成功
  122. Db::name('order')->where('subscriptionId',$data['subscriptionId'])->delete();
  123. return "1111";
  124. //将数据库的订阅数据也删掉
  125. }else{//失败
  126. return $this->error($rescurl[1]);//
  127. }
  128. }
  129. }
  130. public function adddata(){
  131. if ($this->request->isPost()) {
  132. $data = input('');
  133. /* $rand=rand(0,2);
  134. $header=["Content-Type:application/json"];
  135. //将数据分配给不同的服务
  136. $httpserver=["http://47.98.153.212:1101","http://47.98.153.212:1102","http://47.98.153.212:1103"];
  137. $server=$httpserver[$rand];
  138. //将数据随机转发到别的平台做处理
  139. $res=curltest($server,$data,$header);
  140. */
  141. $list = array();
  142. if (is_array($data)) {
  143. $list['data'] = json_encode($data, 320);
  144. $getdata = json_decode($list['data'], true);//转成数组
  145. $list['type'] = 1;
  146. } else {
  147. $list['data'] = $data;
  148. $getdata = json_decode($list['data'], true);//转成数组
  149. $list['type'] = 2;
  150. }
  151. // $list['data']=11;
  152. $list['response'] = "111";
  153. $list['notifyType'] = $getdata["notifyType"];
  154. $list['deviceId'] = $getdata["deviceId"];
  155. $list['addtime'] = date('Y-m-d H:i:s');
  156. $res = Db::name('noticedata')->insertGetId($list);//将推送的数据存入总表
  157. Log::record('deviceId' . ':' . $getdata["service"]["eventTime"]);
  158. //在详细表里插入数据
  159. //根据设备id查找到device里的device_id
  160. if (trim($getdata["notifyType"]) == "deviceDataChanged") {
  161. $device = Db::name('device')->where('iot_id', trim($getdata["deviceId"]))->find();
  162. $datainfo = array();
  163. $datainfo['notifyType'] = $getdata["notifyType"];
  164. $datainfo['device_id'] = $device["device_id"];
  165. $datainfo['iot_id'] = $getdata["deviceId"];
  166. $datainfo['service'] = json_encode($getdata["service"]);
  167. $datainfo['addtime'] = date('Y-m-d H:i:s');
  168. $res1 = Db::table('dev_' . $device["device_id"])->insertGetId($datainfo);
  169. $data2=array();
  170. $data2['devicestatus'] = 0;
  171. $data2['true_status'] = '0';
  172. $data2['lastcommtime'] = date('Y-m-d H:i:s');
  173. $sql2="UPDATE sp_devices_status SET statustime = {$data2['lastcommtime']} devicestatus = {$data2['devicestatus']},true_status={$data2['true_status']},lastcommtime='{$data2['lastcommtime']}' WHERE deviceid='{$device['device_id']}'";
  174. $res2 = addDataInfo($sql2);
  175. if ($device['deviceType']=='Smoke') {
  176. $data3 = array();
  177. $data3['device_id'] = $device["device_id"];
  178. $data3['RSRQ'] = $getdata["service"]['data']['RSRQ'];
  179. $data3['CSQ'] = $getdata["service"]['data']["CSQ"];
  180. $data3['DeviceType'] = $getdata["service"]['data']["DeviceType"];
  181. $data3['DeviceStatus'] = $getdata["service"]['data']["DeviceStatus"];
  182. $data3['BatteryLevel'] = $getdata["service"]['data']["BatteryLevel"];
  183. $data3['SensorLevel'] = $getdata["service"]['data']["SensorLevel"];
  184. $data3['eventTime'] = $getdata["service"]["eventTime"];
  185. $data3['storeTime'] = date('Y-m-d H:i:s');
  186. $sql = "INSERT INTO sp_y{$data3['device_id']} VALUES ('','{$data3['device_id']}',
  187. '{$data3['RSRQ']}', '{$data3['CSQ']}', '{$data3['DeviceType']}','{$data3['DeviceStatus']}','{$data3['BatteryLevel']}','{$data3['SensorLevel']}','{$data3['eventTime']}','{$data3['storeTime']}')";
  188. $res3 = addDataInfo($sql);
  189. } elseif($device['deviceType']=='MultiSensor') {
  190. $data3 = array();
  191. $data3['device_id'] = $device["device_id"];
  192. $data3['port'] = 'tp_water_pressure';
  193. $data3['storeTime'] = date('Y-m-d H:i:s');
  194. $data3['unit'] =$getdata["service"]['data']["unit"];
  195. // $data3['messageId'] = $getdata["service"]['data']["messageId"];
  196. $data3['batteyValue'] = $getdata["service"]['data']["batteyValue"];
  197. $data3['alarmBoolean'] = $getdata["service"]['data']["alarmBoolean"];
  198. $unit=dechex($getdata["service"]['data']["unit"]);
  199. Log::record('sql1234'.':'.$unit);
  200. $sql11="SELECT dwtype FROM sp_owner WHERE owner_code ='{$device["device_id"]}'";
  201. $dwtype = add($sql11);
  202. $arr_y=array('10','11','20','21','22');
  203. if ($dwtype[0]['dwtype'] == 5){
  204. if ($data3['unit']== 1){
  205. $data3['data1']='LL2';
  206. }elseif($data3['unit']== 2){
  207. $data3['data1']='LL1';
  208. }else{
  209. $data3['data1']='LL0';
  210. }
  211. }else {
  212. if ($data3['unit']== 1){
  213. $data3['data1']='WP2';
  214. }elseif($data3['unit']== 2){
  215. $data3['data1']='WP1';
  216. }else{
  217. $data3['data1']='WP0';
  218. }
  219. }
  220. switch ($unit){
  221. case '10':
  222. $data3['data4'] = $getdata["service"]['data']["data"]*0.0001;
  223. break;
  224. case '11':
  225. $data3['data4'] = $getdata["service"]['data']["data"]*0.001;
  226. break;
  227. case '20':
  228. $data3['data4'] = $getdata["service"]['data']["data"]*0.01;
  229. break;
  230. case '21':
  231. $data3['data4'] = $getdata["service"]['data']["data"]*0.1;
  232. break;
  233. case '22':
  234. $data3['data4'] = $getdata["service"]['data']["data"];
  235. break;
  236. case '30':
  237. $data3['data4'] = $getdata["service"]['data']["data"]*0.0000001;
  238. break;
  239. case '31':
  240. $data3['data4'] = $getdata["service"]['data']["data"]*0.000001;
  241. break;
  242. case '40':
  243. $data3['data4'] = $getdata["service"]['data']["data"]*0.00001;
  244. break;
  245. case '41':
  246. $data3['data4'] = $getdata["service"]['data']["data"]*0.0001;
  247. break;
  248. case '42':
  249. $data3['data4'] = $getdata["service"]['data']["data"]*0.001;
  250. break;
  251. case '50':
  252. $data3['data4'] = $getdata["service"]['data']["data"]*0.01;
  253. break;
  254. case '51':
  255. $data3['data4'] = $getdata["service"]['data']["data"]*0.1;
  256. break;
  257. case '52':
  258. $data3['data4'] = $getdata["service"]['data']["data"];
  259. break;
  260. case '2':
  261. $data3['data4'] = $getdata["service"]['data']["data"]*0.001;
  262. break;
  263. }
  264. $data3['data'] = $getdata["service"]['data']["data"];
  265. $sql = "INSERT INTO sp_d{$data3['device_id']} VALUES ('','{$data3['device_id']}','{$data3['port']}','{$data3['storeTime']}',
  266. '','','','{$data3['data1']}','{$data3['batteyValue']}','5','{$data3['data4']}','11111111111')";
  267. // Log::record('sql1234'.':'.$sql);
  268. $res4 = addDataInfo($sql);
  269. }elseif ($device['deviceType']=='WaterMeter'){
  270. //宇洁容情
  271. Log::record('xinshuibiaozhi'.':'.$getdata["service"]['data']['data']);
  272. $data3 = array();
  273. $data3['device_id'] = $device["device_id"];
  274. $data3['port'] = 'tp_water_pressure';
  275. $data3['storeTime'] = date('Y-m-d H:i:s');
  276. $data3['batteyValue'] = dechex($getdata["service"]['data']["battery"]);
  277. $data3['unit'] =dechex($getdata["service"]['data']['data']);
  278. $data3['device_type'] =dechex($getdata["service"]['data']['device_type']);
  279. $data3['address'] = '180.101.147.89';
  280. $data3['alarmBoolean'] = $getdata["service"]['data']["alarm"];
  281. $alarm=dechex($data3['alarmBoolean']);
  282. $data3['sign'] = round($getdata["service"]['data']["signal"]/6);
  283. $data3['coeffice'] = dechex($getdata["service"]['data']["coeffice"]);
  284. if ($data3['alarmBoolean']!== 0){
  285. if ($data3['alarmBoolean']== 161){
  286. $data3['data1']='WP1';
  287. }else{
  288. $data3['data1']='WP2';
  289. }
  290. }else {
  291. $data3['data1'] = 'WP0';
  292. }
  293. if ($data3['device_type']=='ae'){
  294. switch ($data3['coeffice']){
  295. case 'd3':
  296. $data3['data4'] = $data3['unit']*0.001;
  297. break;
  298. case 'd2':
  299. $data3['data4'] = $data3['unit']*0.01;
  300. break;
  301. case 'd1':
  302. $data3['data4'] = $data3['unit']*0.1;
  303. break;
  304. case 'e0':
  305. $data3['data4'] = $data3['unit'];
  306. break;
  307. case 'e1':
  308. $data3['data4'] = $data3['unit']*10;
  309. break;
  310. case 'e2':
  311. $data3['data4'] = $data3['unit']*100;
  312. break;
  313. }
  314. $sql = "INSERT INTO sp_d{$data3['device_id']} VALUES ('','{$data3['device_id']}','{$data3['port']}','{$data3['storeTime']}',
  315. '','','','{$data3['data1']}','{$data3['batteyValue']}','{$data3['sign']}','{$data3['data4']}','11111111111')";
  316. $res5 = addDataInfo($sql);
  317. if ($data3['alarmBoolean']!== 0){
  318. $sql = "INSERT INTO sp_sj2017 VALUES ('','tp_water_pressure','{$data3['device_id']}','{$data3['storeTime']}','$alarm','{$data3['address']}', ''
  319. ,'{$data3['data1']}','{$data3['batteyValue']}','{$data3['sign']}','{$data3['data4']}','','','','','','','','','','')";
  320. $insert_id = addDataInfo($sql);
  321. // $sql66="update sp_devices_status set statustime=".$data3['storeTime'];
  322. // Log::record('sql66'.':'.$sql66);
  323. // $update_id = addDataInfo($sql66);
  324. $insert_id_sql="select id from sp_sj2017 where device_code='".$data3['device_id']."' and time='".$data3['storeTime']."'";
  325. Log::record('sql987'.':'.$insert_id_sql);
  326. $insert_id66=add($insert_id_sql);
  327. Log::record('sql253232'.':'.$insert_id66[0]['id']);
  328. if ($data3['alarmBoolean']== 161){
  329. $msg['evt'] = "WP1";
  330. $msg['msg'] = "低压";
  331. }else{ // high
  332. $msg['evt'] = "WP2";
  333. $msg['msg'] = "高压";
  334. }
  335. if ( $msg['evt']=='WP1' || $msg['evt']=='WP2' ) {
  336. $sql3="select s.owner_name,s.unitinfo,s.company,c.owner_address from sp_owner s ,sp_owner_company c where s.company=c.owner_id and s.owner_code ='{$device["device_id"]}'";
  337. $company = add($sql3);
  338. $sql4="select phone from sp_owner_phone WHERE owner_code='".$company[0]['company']."' AND data2 like '%3%' union select phone from sp_owner_phone WHERE owner_code in (select other_code from sp_owner_fujin where owner_code='".$company[0]['company']."') AND data2 like '%3%'";
  339. $union_sql=add($sql4);
  340. // Log::record('sql12345'.':'.$sql4);
  341. $openids=$this->array_column1($union_sql,"phone");
  342. if (empty($openids))
  343. {
  344. echo 'open is null';
  345. exit;
  346. }
  347. // Log::record('data666_phone'.':'.$openids);
  348. $sql5="SELECT openid FROM sp_wx_customuser WHERE type='wx' and idphone in($openids)";
  349. $op=add($sql5);
  350. $access_token=GetAccess_Token();
  351. $address='警报地址:'.$company[0]['owner_address'].$company[0]['unitinfo'];
  352. $deviceid=$device["device_id"];
  353. $type=$msg['msg'];
  354. $time=$data3['storeTime'];
  355. $remark='设备名称:'.$company[0]['owner_name'];
  356. $url_wx_push2 = "http://www.jd-ioe.com/jdxf/wxapp2.php/Home/Waterwarn/message_water";
  357. Log::record('data666_url_wx_push2'.':'. $url_wx_push2);
  358. $data666['IMEI']=$device["device_id"];
  359. Log::record('data666_IMET'.':'.$data666['IMEI']);
  360. $data666['phone']=$openids;
  361. Log::record('data666_phone'.':'.$data666['phone']);
  362. $data666['evt']=$data3['data1'];
  363. Log::record('data666_evt'.':'.$data666['evt']);
  364. $data666['insert_id']=$insert_id66[0]['id'];
  365. Log::record('data666_insert_id'.':'.$data666['insert_id']);
  366. // Log::record('data666'.':'.$data666);
  367. $sql88="UPDATE sp_devices_status SET statustime ='".$data3['storeTime']."' where deviceid='".$data666['IMEI']."'";
  368. addDataInfo($sql88);
  369. $this->curl($url_wx_push2,$data666);
  370. // $url_wx_push2 = "http://www.jd-ioe.com/jdxf/wxapp2.php/Home/Waterwarn/bj";
  371. foreach($op as $key => $o){
  372. if (!empty($o['openid']))
  373. {
  374. // $data88['openid']=$o['openid'];
  375. // $data88['address']=$address;
  376. // $data88['deviceid']=$deviceid;
  377. // $data88['type']=$type;
  378. // $data88['time']=$time;
  379. // $data88['remark']=$remark;
  380. //token,微信id,地址,设备号,类型,时间,设备名称(或者其他内容)
  381. //{{first.DATA}}$address
  382. //设备号:{{keyword1.DATA}}$deviceid
  383. //报警类型:{{keyword2.DATA}}$type
  384. //时间:{{keyword3.DATA}}$time
  385. //{{remark.DATA}}$remark
  386. $Message=$this->SendDeviceAlarm($access_token,$o['openid'],$address,$deviceid,$type,$time,$remark,$url='');
  387. // s_curl($url_wx_push2,$data88);
  388. $Message['openid']=$o['openid'];
  389. $arr[$key]=$Message;
  390. }
  391. }
  392. }
  393. }
  394. }
  395. }elseif ($device['deviceType']=='topsailSensor'){
  396. //拓普索尔
  397. Log::record('tuopusuoershuibiao'.':'.$getdata["service"]['data']['Imei']);
  398. $data3 = array();
  399. $data3['device_id'] = $device["device_id"];
  400. $data3['port'] = 'TuoPuSuoEr-TSM-04P';
  401. $data3['storeTime'] = date('Y-m-d H:i:s');
  402. $data3['batteyValue'] = $getdata["service"]['data']["batteryLevel"];
  403. $data3['data'] =substr($getdata["service"]['data']["sampleData"],-5);
  404. $data3['unit'] =substr($getdata["service"]['data']["sampleData"],0,1);
  405. $data3['device_type'] =$getdata["service"]['data']['deviceType'];
  406. $data3['sendTime'] =$getdata["service"]['data']['sendTime'];
  407. $data3['address'] = '180.101.147.89';
  408. $data3['alarmBoolean'] = $getdata["service"]['data']["alarmType"];
  409. $data3['sign'] = round($getdata["service"]['data']["signalStrength"]/6);
  410. if ($data3['alarmBoolean']!== '0'){
  411. if ($data3['alarmBoolean']== '1'){
  412. $data3['data1']='WP1';
  413. }elseif ($data3['alarmBoolean']== '2'){
  414. $data3['data1']='WP2';
  415. }
  416. }else {
  417. $data3['data1'] = 'WP0';
  418. }
  419. if (!empty($data3['sendTime'])) {
  420. switch ($data3['unit']) {
  421. case '0':
  422. $data3['data4'] = $data3['data'] * 1;
  423. break;
  424. case '1':
  425. $data3['data4'] = $data3['data'] * 0.1;
  426. break;
  427. case '2':
  428. $data3['data4'] = $data3['data'] * 0.01;
  429. break;
  430. case '3':
  431. $data3['data4'] = $data3['data'] * 0.001;
  432. break;
  433. case '4':
  434. $data3['data4'] = $data3['data'] * 0.0001;
  435. break;
  436. }
  437. $sql = "INSERT INTO sp_d{$data3['device_id']} VALUES ('','{$data3['device_id']}','{$data3['port']}','{$data3['storeTime']}',
  438. '','','','{$data3['data1']}','{$data3['batteyValue']}','{$data3['sign']}','{$data3['data4']}','11111111111')";
  439. $res5 = addDataInfo($sql);
  440. if ($data3['alarmBoolean']!== '0'){
  441. $sql = "INSERT INTO sp_sj2017 VALUES ('','TuoPuSuoEr-TSM-04P','{$data3['device_id']}','{$data3['storeTime']}','{$data3['alarmBoolean']}','{$data3['address']}', ''
  442. ,'{$data3['data1']}','{$data3['batteyValue']}','{$data3['sign']}','{$data3['data4']}','','','','','','','','','','')";
  443. $insert_id = addDataInfo($sql);
  444. // $sql66="update sp_devices_status set statustime=".$data3['storeTime'];
  445. // Log::record('sql66'.':'.$sql66);
  446. // $update_id = addDataInfo($sql66);
  447. $insert_id_sql="select id from sp_sj2017 where device_code='".$data3['device_id']."' and time='".$data3['storeTime']."'";
  448. Log::record('sql98725'.':'.$insert_id_sql);
  449. $insert_id66=add($insert_id_sql);
  450. if ($data3['alarmBoolean']== '1'){
  451. $msg['evt'] = "WP1";
  452. $msg['msg'] = "低压";
  453. }elseif ($data3['alarmBoolean']== '2'){ // high
  454. $msg['evt'] = "WP2";
  455. $msg['msg'] = "高压";
  456. }
  457. if ( $msg['evt']=='WP1' || $msg['evt']=='WP2' ) {
  458. $sql3="select s.owner_name,s.unitinfo,s.company,c.owner_address from sp_owner s ,sp_owner_company c where s.company=c.owner_id and s.owner_code ='{$device["device_id"]}'";
  459. $company = add($sql3);
  460. $sql4="select phone from sp_owner_phone WHERE owner_code='".$company[0]['company']."' AND data2 like '%3%' union select phone from sp_owner_phone WHERE owner_code in (select other_code from sp_owner_fujin where owner_code='".$company[0]['company']."') AND data2 like '%3%'";
  461. $union_sql=add($sql4);
  462. // Log::record('sql12345'.':'.$sql4);
  463. $openids=$this->array_column1($union_sql,"phone");
  464. if (empty($openids))
  465. {
  466. echo 'open is null';
  467. exit;
  468. }
  469. // Log::record('data666_phone'.':'.$openids);
  470. $sql5="SELECT openid FROM sp_wx_customuser WHERE type='wx' and idphone in($openids)";
  471. $op=add($sql5);
  472. $access_token=GetAccess_Token();
  473. $address='警报地址:'.$company[0]['owner_address'].$company[0]['unitinfo'];
  474. $deviceid=$device["device_id"];
  475. $type=$msg['msg'];
  476. $time=$data3['storeTime'];
  477. $remark='设备名称:'.$company[0]['owner_name'];
  478. $url_wx_push2 = "http://www.jd-ioe.com/jdxf/wxapp2.php/Home/Waterwarn/message_water";
  479. Log::record('data666_url_wx_push2'.':'. $url_wx_push2);
  480. $data666['IMEI']=$device["device_id"];
  481. Log::record('data666_IMET'.':'.$data666['IMEI']);
  482. $data666['phone']=$openids;
  483. Log::record('data666_phone'.':'.$data666['phone']);
  484. $data666['evt']=$data3['data1'];
  485. Log::record('data666_evt'.':'.$data666['evt']);
  486. $data666['insert_id']=$insert_id66[0]['id'];
  487. Log::record('data666_insert_id'.':'.$data666['insert_id']);
  488. // Log::record('data666'.':'.$data666);
  489. $sql88="UPDATE sp_devices_status SET statustime ='".$data3['storeTime']."' where deviceid='".$data666['IMEI']."'";
  490. addDataInfo($sql88);
  491. $this->curl($url_wx_push2,$data666);
  492. // $url_wx_push2 = "http://www.jd-ioe.com/jdxf/wxapp2.php/Home/Waterwarn/bj";
  493. foreach($op as $key => $o){
  494. if (!empty($o['openid']))
  495. {
  496. $Message=$this->SendDeviceAlarm($access_token,$o['openid'],$address,$deviceid,$type,$time,$remark,$url='');
  497. // s_curl($url_wx_push2,$data88);
  498. $Message['openid']=$o['openid'];
  499. $arr[$key]=$Message;
  500. }
  501. }
  502. }
  503. }
  504. }
  505. }
  506. if ($device['deviceType']=='Smoke') {
  507. if ($getdata["service"]['data']["DeviceStatus"]!== 7){
  508. $arr_bit = array(
  509. "","报警","报警静音","保留","低压","故障","保留"
  510. );
  511. $deviceStatus=$getdata["service"]['data']["DeviceStatus"];
  512. $data3 = array();
  513. $data3['device_code'] = $device["device_id"];
  514. $data3['time'] = date('Y-m-d H:i:s');
  515. $data3['status'] = 'y'.'0'.$deviceStatus;
  516. $data3['address'] = '180.101.147.89';
  517. $data3['compartment'] = '';
  518. $data3['fireprocess'] = '';
  519. $data3['flowendtime'] = '0000-00-00 00:00:00';
  520. $data3['ncmd'] = 'y'.'0'.$deviceStatus;
  521. $data3['data1'] = 'y'.'0'.$deviceStatus;
  522. $data3['data2'] = $arr_bit["{$deviceStatus}"];
  523. $data3['data3'] = '';
  524. $data3['data4'] = '烟雾'.$arr_bit["{$deviceStatus}"];
  525. $data3['data5'] = '';
  526. $sql = "INSERT INTO sp_hj2017 VALUES ('','','{$data3['device_code']}','{$data3['time']}','{$data3['status']}','{$data3['address']}','{$data3['compartment']}',
  527. '{$data3['fireprocess']}', '{$data3['flowendtime']}', '{$data3['ncmd']}','{$data3['data1']}','{$data3['data2']}','{$data3['data3']}','{$data3['data4']}','{$data3['data5']}','','',''
  528. ,'','','','','','')";
  529. $res5 = addDataInfo($sql);
  530. $insert_id_sql="select id from sp_hj2017 where device_code='".$data3['device_code']."' and time='".$data3['time']."'";
  531. Log::record('sql66886688'.':'.$insert_id_sql);
  532. $insert_id66=add($insert_id_sql);
  533. // $sql66="update sp_devices_status set statustime=".$data3['time'];
  534. // Log::record('sql66'.':'.$sql66);
  535. // $update_id = addDataInfo($sql66);
  536. }
  537. $arr_h=array(1,2);
  538. if (in_array($getdata["service"]['data']["DeviceStatus"],$arr_h)){
  539. $sql3="select s.owner_name,s.unitinfo,s.company,c.owner_address from sp_owner s ,sp_owner_company c where s.company=c.owner_id and s.owner_code ='{$device["device_id"]}'";
  540. Log::record('sql3'.':'.$sql3);
  541. $company = add($sql3);
  542. Log::record('company'.':'.$company[0]['company']);
  543. $sql4="select phone from sp_owner_phone WHERE owner_code='".$company[0]['company']."' AND data2 like '%6%' union select phone from sp_owner_phone WHERE owner_code in (select other_code from sp_owner_fujin where owner_code='".$company[0]['company']."') AND data2 like '%6%'";
  544. Log::record('sql4'.':'.$sql4);
  545. $union_sql=add($sql4);
  546. $openids=$this->array_column1($union_sql,"phone");
  547. if (empty($openids))
  548. {
  549. echo 'open is null';
  550. exit;
  551. }
  552. $sql5="SELECT openid FROM sp_wx_customuser WHERE type='wx' and idphone in($openids)";
  553. $op=add($sql5);
  554. $access_token=GetAccess_Token();
  555. $address='警报地址:'.$company[0]['owner_address'].$company[0]['unitinfo'];
  556. $deviceid=$device["device_id"];
  557. $type='烟雾';
  558. $time=$data3['time'];
  559. $remark='设备名称:'.$company[0]['owner_name'];
  560. $url_wx_push2 = "http://www.jd-ioe.com/jdxf/wxapp2.php/Home/Waterwarn/bj";
  561. Log::record('data666_url_wx_push2'.':'.$url_wx_push2);
  562. $data666['phone']=$openids;
  563. Log::record('data666_phone'.':'.$data666['phone']);
  564. $data666['IMEI']=$device["device_id"];
  565. Log::record('data666_IMEI'.':'.$data666['IMEI']);
  566. $data666['time']=$data3['time'];
  567. Log::record('data666_time'.':'.$data666['time']);
  568. $data666['evt']=$data3['data1'];
  569. Log::record('data666_evt'.':'.$data666['evt']);
  570. $data666['insert_id']=$insert_id66[0]['id'];
  571. Log::record('data666_insert_id'.':'.$data666['insert_id']);
  572. $this->curl($url_wx_push2,$data666);
  573. foreach($op as $key => $o){
  574. if (!empty($o['openid']))
  575. {
  576. $Message=$this->SendDeviceAlarm($access_token,$o['openid'],$address,$deviceid,$type,$time,$remark,$url='');
  577. // s_curl($url_wx_push2,$data88);
  578. $Message['openid']=$o['openid'];
  579. $arr[$key]=$Message;
  580. }
  581. }
  582. }
  583. } elseif($device['deviceType']=='MultiSensor') {
  584. if($getdata["service"]['data']["alarmBoolean"]== 17){
  585. // $sql1="SELECT * from 'dev_' . {$device["device_id"]} where addtime=(select max(addtime) from 'dev_' . {$device["device_id"]})";
  586. // $Model = M();
  587. // $result = $Model->query($sql1);
  588. // $service=json_decode($result['']['service']);
  589. $unit=dechex($getdata["service"]['data']["unit"]);
  590. $data3 = array();
  591. $data3['device_code'] = $device["device_id"];
  592. $data3['time'] = date('Y-m-d H:i:s');
  593. $data3['status'] = $getdata["service"]['data']["alarmBoolean"];
  594. $data3['address'] = '180.101.147.89';
  595. $data3['ncmd'] = '';
  596. $data3['unit'] =$getdata["service"]['data']["unit"];
  597. $arr_y=array('10','11','20','21','22');
  598. $sql11="SELECT dwtype FROM sp_owner WHERE owner_code ='{$device["device_id"]}'";
  599. $dwtype = add($sql11);
  600. if ($dwtype[0]['dwtype'] == 5){
  601. if ($data3['unit']== 1){
  602. $data3['data1']='LL2';
  603. }elseif($data3['unit']== 2){
  604. $data3['data1']='LL1';
  605. }else{
  606. $data3['data1']='LL0';
  607. }
  608. }else {
  609. if ($data3['unit']== 1){
  610. $data3['data1']='WP2';
  611. }elseif($data3['unit']== 2){
  612. $data3['data1']='WP1';
  613. }else{
  614. $data3['data1']='WP0';
  615. }
  616. }
  617. $data3['data2'] = $getdata["service"]['data']["batteyValue"];
  618. $data3['data3'] = '';
  619. switch ($unit){
  620. case '10':
  621. $data3['data4'] = $getdata["service"]['data']["data"]*0.0001;
  622. break;
  623. case '11':
  624. $data3['data4'] = $getdata["service"]['data']["data"]*0.001;
  625. break;
  626. case '20':
  627. $data3['data4'] = $getdata["service"]['data']["data"]*0.01;
  628. break;
  629. case '21':
  630. $data3['data4'] = $getdata["service"]['data']["data"]*0.1;
  631. break;
  632. case '22':
  633. $data3['data4'] = $getdata["service"]['data']["data"];
  634. break;
  635. case '30':
  636. $data3['data4'] = $getdata["service"]['data']["data"]*0.0000001;
  637. break;
  638. case '31':
  639. $data3['data4'] = $getdata["service"]['data']["data"]*0.000001;
  640. break;
  641. case '40':
  642. $data3['data4'] = $getdata["service"]['data']["data"]*0.00001;
  643. break;
  644. case '41':
  645. $data3['data4'] = $getdata["service"]['data']["data"]*0.0001;
  646. break;
  647. case '42':
  648. $data3['data4'] = $getdata["service"]['data']["data"]*0.001;
  649. break;
  650. case '50':
  651. $data3['data4'] = $getdata["service"]['data']["data"]*0.01;
  652. break;
  653. case '51':
  654. $data3['data4'] = $getdata["service"]['data']["data"]*0.1;
  655. break;
  656. case '52':
  657. $data3['data4'] = $getdata["service"]['data']["data"];
  658. break;
  659. case '2':
  660. $data3['data4'] = $getdata["service"]['data']["data"]*0.001;
  661. break;
  662. }
  663. $data3['data5'] = '';
  664. $sql = "INSERT INTO sp_sj2017 VALUES ('','tp_water_pressure','{$data3['device_code']}','{$data3['time']}','{$data3['status']}','{$data3['address']}', '{$data3['ncmd']}'
  665. ,'{$data3['data1']}','{$data3['data2']}','{$data3['data3']}','{$data3['data4']}','{$data3['data5']}','','','','','','','','','')";
  666. // Log::record('sql123'.':'.$sql);
  667. $insert_id = addDataInfo($sql);
  668. $insert_id_sql="select id from sp_sj2017 where device_code='".$data3['device_id']."' and time='".$data3['time']."'";
  669. Log::record('sql987253232'.':'.$insert_id_sql);
  670. $insert_id66=add($insert_id_sql);
  671. if ($dwtype[0]['dwtype'] == 5) {
  672. if ($getdata["service"]['data']["unit"] == '1') {
  673. $msg['evt'] = "WP2";
  674. $msg['msg'] = "高水位";
  675. } elseif ($getdata["service"]['data']["unit"] == '2') { // high
  676. $msg['evt'] = "WP1";
  677. $msg['msg'] = "低水位";
  678. }
  679. }else{
  680. if ($getdata["service"]['data']["unit"] == '1') {
  681. $msg['evt'] = "WP2";
  682. $msg['msg'] = "高压";
  683. } elseif ($getdata["service"]['data']["unit"] == '2') { // high
  684. $msg['evt'] = "WP1";
  685. $msg['msg'] = "低压";
  686. }
  687. }
  688. if ( $msg['evt']=='WP1' || $msg['evt']=='WP2' ) {
  689. $sql3="select s.owner_name,s.unitinfo,s.company,c.owner_address from sp_owner s ,sp_owner_company c where s.company=c.owner_id and s.owner_code ='{$device["device_id"]}'";
  690. $company = add($sql3);
  691. $sql4="select phone from sp_owner_phone WHERE owner_code='".$company[0]['company']."' AND data2 like '%3%' union select phone from sp_owner_phone WHERE owner_code in (select other_code from sp_owner_fujin where owner_code='".$company[0]['company']."') AND data2 like '%3%'";
  692. $union_sql=add($sql4);
  693. Log::record('sql12345'.':'.$sql4);
  694. $openids=$this->array_column1($union_sql,"phone");
  695. if (empty($openids))
  696. {
  697. echo 'open is null';
  698. exit;
  699. }
  700. Log::record('data666_phone'.':'.$openids);
  701. $sql5="SELECT openid FROM sp_wx_customuser WHERE type='wx' and idphone in($openids)";
  702. $op=add($sql5);
  703. $access_token=GetAccess_Token();
  704. $address='警报地址:'.$company[0]['owner_address'].$company[0]['unitinfo'];
  705. $deviceid=$device["device_id"];
  706. $type=$msg['msg'];
  707. $time=$data3['time'];
  708. $remark='设备名称:'.$company[0]['owner_name'];
  709. //
  710. $url_wx_push2 = "http://www.jd-ioe.com/jdxf/wxapp2.php/Home/Waterwarn/message_water";
  711. Log::record('data666_url_wx_push2'.':'. $url_wx_push2);
  712. $data666['IMEI']=$device["device_id"];
  713. Log::record('data666_IMET'.':'.$data666['IMEI']);
  714. $data666['phone']=$openids;
  715. Log::record('data666_phone'.':'.$data666['phone']);
  716. $data666['evt']=$data3['data1'];
  717. Log::record('data666_evt'.':'.$data666['evt']);
  718. $data666['insert_id']=$insert_id66[0]['id'];
  719. Log::record('data666_insert_id'.':'.$data666['insert_id']);
  720. // Log::record('data666'.':'.$data666);
  721. $sql88="UPDATE sp_devices_status SET statustime ='".$data3['time']."' where deviceid='".$data666['IMEI']."'";
  722. addDataInfo($sql88);
  723. $this->curl($url_wx_push2,$data666);
  724. // $url_wx_push2 = "http://www.jd-ioe.com/jdxf/wxapp2.php/Home/Waterwarn/bj";
  725. foreach($op as $key => $o){
  726. if (!empty($o['openid']))
  727. {
  728. // $data88['openid']=$o['openid'];
  729. // $data88['address']=$address;
  730. // $data88['deviceid']=$deviceid;
  731. // $data88['type']=$type;
  732. // $data88['time']=$time;
  733. // $data88['remark']=$remark;
  734. //token,微信id,地址,设备号,类型,时间,设备名称(或者其他内容)
  735. //{{first.DATA}}$address
  736. //设备号:{{keyword1.DATA}}$deviceid
  737. //报警类型:{{keyword2.DATA}}$type
  738. //时间:{{keyword3.DATA}}$time
  739. //{{remark.DATA}}$remark
  740. $Message=$this->SendDeviceAlarm($access_token,$o['openid'],$address,$deviceid,$type,$time,$remark,$url='');
  741. // s_curl($url_wx_push2,$data88);
  742. $Message['openid']=$o['openid'];
  743. $arr[$key]=$Message;
  744. }
  745. }
  746. }
  747. }
  748. }
  749. }
  750. return json_encode($data, 320);
  751. }
  752. }
  753. public function addtuobaodata(){
  754. if ($this->request->isPost()) {
  755. $data = input('');
  756. $list = array();
  757. if (is_array($data)) {
  758. $list['data'] = json_encode($data, 320);
  759. $getdata = json_decode($list['data'], true);//转成数组
  760. $list['type'] = 1;
  761. } else {
  762. $list['data'] = $data;
  763. $getdata = json_decode($list['data'], true);//转成数组
  764. $list['type'] = 2;
  765. }
  766. // $list['data']=11;
  767. $list['response'] = "222";
  768. $list['notifyType'] = $getdata["notifyType"];
  769. $list['deviceId'] = $getdata["deviceId"];
  770. $list['addtime'] = date('Y-m-d H:i:s');
  771. $res = Db::name('noticedata')->insertGetId($list);//将推送的数据存入总表
  772. if (trim($getdata["notifyType"]) == "deviceDataChanged") {
  773. $device = Db::name('device')->where('iot_id', trim($getdata["deviceId"]))->find();
  774. Log::record('tuobaoceshi123' . ':' . $device["device_id"]);
  775. $datainfo = array();
  776. $datainfo['notifyType'] = $getdata["notifyType"];
  777. $datainfo['device_id'] = $device["device_id"];
  778. $datainfo['iot_id'] = $getdata["deviceId"];
  779. $datainfo['service'] = json_encode($getdata["service"]);
  780. $datainfo['addtime'] = date('Y-m-d H:i:s');
  781. $res1 = Db::table('dev_' . $device["device_id"])->insertGetId($datainfo);
  782. if ($device['deviceType']=='SaiTeSmoke') {
  783. $data3 = array();
  784. $data3['device_id'] = $device["device_id"];
  785. $data3['RSRQ'] = $getdata["service"]['data']['RSRP'];
  786. $data3['CSQ'] = $getdata["service"]['data']["CSQ"];
  787. $data3['DeviceType'] = 1;
  788. if ($getdata["service"]['data']["Alarm_Status"]!== 7) {
  789. $data3['DeviceStatus'] = 1;
  790. }else{
  791. $data3['DeviceStatus'] = 7;
  792. }
  793. $data3['BatteryLevel'] = $getdata["service"]['data']["Battery_Level"];
  794. $data3['SensorLevel'] = $getdata["service"]['data']["AlarmLevel"];
  795. $data3['TData'] = $getdata["service"]['data']["TData"];
  796. $data3['eventTime'] = $getdata["service"]["eventTime"];
  797. $data3['storeTime'] = date('Y-m-d H:i:s');
  798. $sql = "INSERT INTO sp_y{$data3['device_id']} VALUES ('','{$data3['device_id']}',
  799. '{$data3['RSRQ']}', '{$data3['CSQ']}', '{$data3['DeviceType']}','{$data3['DeviceStatus']}','{$data3['BatteryLevel']}','{$data3['SensorLevel']}','{$data3['eventTime']}','{$data3['storeTime']}','{$data3['TData']}')";
  800. $res3 = addDataInfo($sql);
  801. if ($getdata["service"]['data']["Alarm_Status"]!== 7){
  802. $arr_bit = array(
  803. "","报警","静音","保留","低压","故障","数据异常","","设备收到单次静音指令","设备收到连续静音指令","拆卸报警","拆卸恢复","","","模拟报警"
  804. );
  805. $deviceStatus=$getdata["service"]['data']["Alarm_Status"];
  806. $data3 = array();
  807. $data3['device_code'] = $device["device_id"];
  808. $data3['time'] = date('Y-m-d H:i:s');
  809. $data3['status'] = 'y'.'0'.$deviceStatus;
  810. $data3['address'] = '180.101.147.89';
  811. $data3['compartment'] = '';
  812. $data3['fireprocess'] = '';
  813. $data3['flowendtime'] = '0000-00-00 00:00:00';
  814. $data3['ncmd'] = 'y'.'01';
  815. $data3['data1'] = 'y'.'01';
  816. $data3['data2'] = $arr_bit["{$deviceStatus}"];
  817. $data3['data3'] = '';
  818. $data3['data4'] = '烟雾'.$arr_bit["{$deviceStatus}"];
  819. $data3['data5'] = '';
  820. $sql = "INSERT INTO sp_hj2017 VALUES ('','','{$data3['device_code']}','{$data3['time']}','{$data3['status']}','{$data3['address']}','{$data3['compartment']}',
  821. '{$data3['fireprocess']}', '{$data3['flowendtime']}', '{$data3['ncmd']}','{$data3['data1']}','{$data3['data2']}','{$data3['data3']}','{$data3['data4']}','{$data3['data5']}','','',''
  822. ,'','','','','','')";
  823. $res5 = addDataInfo($sql);
  824. $insert_id_sql="select id from sp_hj2017 where device_code='".$data3['device_code']."' and time='".$data3['time']."'";
  825. Log::record('sql6688668866'.':'.$insert_id_sql);
  826. $insert_id66=add($insert_id_sql);
  827. $arr_h=array(1,2,6,8,9,10,11,14);
  828. if (in_array($getdata["service"]['data']["Alarm_Status"],$arr_h)){
  829. $sql3="select s.owner_name,s.unitinfo,s.company,c.owner_address from sp_owner s ,sp_owner_company c where s.company=c.owner_id and s.owner_code ='{$device["device_id"]}'";
  830. Log::record('sql3'.':'.$sql3);
  831. $company = add($sql3);
  832. Log::record('company'.':'.$company[0]['company']);
  833. $sql4="select phone from sp_owner_phone WHERE owner_code='".$company[0]['company']."' AND data2 like '%6%' union select phone from sp_owner_phone WHERE owner_code in (select other_code from sp_owner_fujin where owner_code='".$company[0]['company']."') AND data2 like '%6%'";
  834. Log::record('sql4'.':'.$sql4);
  835. $union_sql=add($sql4);
  836. $openids=$this->array_column1($union_sql,"phone");
  837. if (empty($openids))
  838. {
  839. echo 'open is null';
  840. exit;
  841. }
  842. $sql5="SELECT openid FROM sp_wx_customuser WHERE type='wx' and idphone in($openids)";
  843. $op=add($sql5);
  844. $access_token=GetAccess_Token();
  845. $address='警报地址:'.$company[0]['owner_address'].$company[0]['unitinfo'];
  846. $deviceid=$device["device_id"];
  847. $type='烟雾';
  848. $time=$data3['time'];
  849. $remark='设备名称:'.$company[0]['owner_name'];
  850. if($getdata["service"]['data']["Alarm_Status"]==10){
  851. $deviceStatus1='y05';
  852. }elseif ($getdata["service"]['data']["Alarm_Status"]==14){
  853. $deviceStatus1='y01';
  854. }
  855. $url_wx_push2 = "http://www.jd-ioe.com/jdxf/wxapp2.php/Home/Waterwarn/bj";
  856. Log::record('data666_url_wx_push2'.':'.$url_wx_push2);
  857. $data666['phone']=$openids;
  858. Log::record('data666_phone'.':'.$data666['phone']);
  859. $data666['IMEI']=$device["device_id"];
  860. Log::record('data666_IMEI'.':'.$data666['IMEI']);
  861. $data666['time']=$data3['time'];
  862. Log::record('data666_time'.':'.$data666['time']);
  863. $data666['evt']=$deviceStatus1;
  864. Log::record('data666_evt'.':'.$data666['evt']);
  865. $data666['insert_id']=$insert_id66[0]['id'];
  866. Log::record('data666_insert_id'.':'.$data666['insert_id']);
  867. $this->curl($url_wx_push2,$data666);
  868. foreach($op as $key => $o){
  869. if (!empty($o['openid']))
  870. {
  871. $Message=$this->SendDeviceAlarm($access_token,$o['openid'],$address,$deviceid,$type,$time,$remark,$url='');
  872. // s_curl($url_wx_push2,$data88);
  873. $Message['openid']=$o['openid'];
  874. $arr[$key]=$Message;
  875. }
  876. }
  877. }
  878. }
  879. }
  880. }
  881. }
  882. }
  883. public function jingan(){
  884. if ($this->request->isPost()) {
  885. Log::record('jinganxiaofang' . ':ceshi');
  886. $data = input('');
  887. /* $rand=rand(0,2);
  888. $header=["Content-Type:application/json"];
  889. //将数据分配给不同的服务
  890. $httpserver=["http://47.98.153.212:1101","http://47.98.153.212:1102","http://47.98.153.212:1103"];
  891. $server=$httpserver[$rand];
  892. //将数据随机转发到别的平台做处理
  893. $res=curltest($server,$data,$header);
  894. */
  895. $list = array();
  896. if (is_array($data)) {
  897. $list['data'] = json_encode($data, 320);
  898. $getdata = json_decode($list['data'], true);//转成数组
  899. } else {
  900. $list['data'] = $data;
  901. $getdata = json_decode($list['data'], true);//转成数组
  902. }
  903. // $list['data']=11;
  904. // $list['response'] = "111";
  905. //
  906. // $list['notifyType'] = $getdata["notifyType"];
  907. // $list['deviceId'] = $getdata["deviceId"];
  908. // $list['addtime'] = date('Y-m-d H:i:s');
  909. $res = Db::name('jingandata')->insertGetId($list);//将推送的数据存入总表
  910. Log::record('jinganxiaofang' . ':' . $res);
  911. return "success";
  912. }
  913. }
  914. public function testdata1(){
  915. $rand=rand(0,2);
  916. $data=[
  917. '{"notifyType":"deviceDataChanged","deviceId":"a1d88da9-5156-4507-995a-bb20af09001a","gatewayId":"a1d88da9-5156-4507-995a-bb20af09001a","requestId":null,"service":{"serviceId":"hxkcnbdtu","serviceType":"hxkcnbdtu","data":{"deviceAddress":"868744030057305","framenumber":0,"framenum":0,"frameser":0,"voltage":3.6,"rsrp":-99.9,"snr":67,"ecl":0,"csq":11,"cellid":"0125145939","reportway":0,"cycle":1600,"setmode":3,"settime":"3-00","freezday":"28-02","nbtime":"18-09-21 10:30:15","pressure":0.7455,"alarm_en":0,"alarm_time":60,"down_alarm_pre":0,"up_alarm_pre":0,"pre_status":0,"log":"7E64E7834300000011395914250100064003030028021809211030151811112222011F1D0000003C00000000000000000000000000","eventTime":"2018-09-21 10:30:17"},"eventTime":"20180921T023017Z"}}',
  918. '{"notifyType":"deviceDataChanged","deviceId":"a1d88da9-5156-4507-995a-bb20af09001a","gatewayId":"a1d88da9-5156-4507-995a-bb20af09001a","requestId":null,"service":{"serviceId":"hxkcnbdtu","serviceType":"hxkcnbdtu","data":{"deviceAddress":"868744030057305","framenumber":0,"framenum":0,"frameser":0,"voltage":3.6,"rsrp":-99.9,"snr":67,"ecl":0,"csq":11,"cellid":"0125145939","reportway":0,"cycle":1600,"setmode":3,"settime":"3-00","freezday":"28-02","nbtime":"18-09-21 10:30:15","pressure":0.7455,"alarm_en":0,"alarm_time":60,"down_alarm_pre":0,"up_alarm_pre":0,"pre_status":0,"log":"7E64E7834300000011395914250100064003030028021809211030151811112222011F1D0000003C00000000000000000000000000","eventTime":"2018-09-21 10:30:17"},"eventTime":"20180921T023017Z"}}',
  919. '{"notifyType":"deviceDataChanged","deviceId":"a1d88da9-5156-4507-995a-bb20af09001a","gatewayId":"a1d88da9-5156-4507-995a-bb20af09001a","requestId":null,"service":{"serviceId":"hxkcnbdtu","serviceType":"hxkcnbdtu","data":{"deviceAddress":"868744030057305","framenumber":0,"framenum":0,"frameser":0,"voltage":3.6,"rsrp":-99.9,"snr":67,"ecl":0,"csq":11,"cellid":"0125145939","reportway":0,"cycle":1600,"setmode":3,"settime":"3-00","freezday":"28-02","nbtime":"18-09-21 10:30:15","pressure":0.7455,"alarm_en":0,"alarm_time":60,"down_alarm_pre":0,"up_alarm_pre":0,"pre_status":0,"log":"7E64E7834300000011395914250100064003030028021809211030151811112222011F1D0000003C00000000000000000000000000","eventTime":"2018-09-21 10:30:17"},"eventTime":"20180921T023017Z"}}',
  920. ];
  921. $header=["Content-Type:application/json"];
  922. //将数据分配给不同的服务
  923. $httpserver=["http://47.98.153.212:1101","http://47.98.153.212:1102","http://47.98.153.212:1103"];
  924. $senddata=$data[$rand];
  925. $server=$httpserver[$rand];
  926. $res=curltest($server,$senddata,$header);
  927. dump($res);
  928. /* //设备所属公司
  929. $owner=Db::name('device')->field("owner_id")->where('iot_id',$iot_id)->find();
  930. $ownerhost=Db::name('owner')->where('id',$owner["owner_id"])->find();
  931. $ipaddr=$ownerhost['host'].":".$ownerhost['port'];
  932. $res=curltest($ipaddr,$senddata);
  933. dump($res);*/
  934. //将数据转发到不同的接口中
  935. /* $sendapi="senddata".$rand;
  936. echo $this->$sendapi($data[$rand],$devies[$rand]);*/
  937. }
  938. public function senddata0($data){
  939. //将数据存到总表
  940. //将数据存到设备详细表
  941. //查看当前设备属于哪家业主
  942. //查找业主的服务器
  943. //给服务器发数据
  944. }
  945. public function senddata1($data){
  946. echo "m2".$data;
  947. }
  948. public function senddata2($data){
  949. echo "m3".$data;
  950. }
  951. public function array_column1($rows, $column_key, $index_key = null) {
  952. $data = array();
  953. if (empty($index_key)) {
  954. foreach ($rows as $row) {
  955. $data[] = $row[$column_key];
  956. }
  957. $data=implode(",",$data);
  958. } else {
  959. foreach ($rows as $row) {
  960. $data[$row[$index_key]] = $row[$column_key];
  961. }
  962. }
  963. return $data;
  964. }
  965. public function SendDeviceAlarm($access_token,$openid,$address,$deviceid,$type,$time,$remark,$url){
  966. $data = array(
  967. "touser"=> $openid,
  968. "template_id"=>"JkQYUiScfIuH9O4vvUgtgYxPIOBOY7Zh9w2DcWTgm50",
  969. //"url" =>"http://zt-iot.com/ztxf/weixin.php/Home/Fire/water",
  970. "data"=> array(
  971. "first"=> array(
  972. "value"=> $address,
  973. "color"=>"#44b549"
  974. ),
  975. "keyword1"=>array(
  976. "value"=> $deviceid,
  977. "color"=>"#173177"
  978. ),
  979. "keyword2"=> array(
  980. "value"=> $type,
  981. "color"=>"#173177"
  982. ),
  983. "keyword3"=> array(
  984. "value"=> $time,
  985. "color"=>"#173177"
  986. ),
  987. "remark"=>array(
  988. "value"=> $remark,
  989. "color"=>"#aaaaaa"
  990. )
  991. )
  992. );
  993. //{{first.DATA}}
  994. //设备号:{{keyword1.DATA}}
  995. //报警类型:{{keyword2.DATA}}
  996. //时间:{{keyword3.DATA}}
  997. //{{remark.DATA}}
  998. $data = json_encode($data);
  999. $QUEST_URL = "https://api.weixin.qq.com/cgi-bin/message/template/send?access_token=".$access_token;
  1000. $res = $this->curl($QUEST_URL,$data);
  1001. return json_decode($res,true);
  1002. }
  1003. public function curl($url,$data=''){
  1004. $ch = curl_init();
  1005. curl_setopt($ch, CURLOPT_URL, $url);
  1006. curl_setopt($ch, CURLOPT_CUSTOMREQUEST, "POST");
  1007. curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, FALSE);
  1008. curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, FALSE);
  1009. curl_setopt($ch, CURLOPT_USERAGENT, 'Mozilla/5.0 (compatible; MSIE 5.01; Windows NT 5.0)');
  1010. curl_setopt($ch, CURLOPT_FOLLOWLOCATION, 1);
  1011. curl_setopt($ch, CURLOPT_AUTOREFERER, 1);
  1012. curl_setopt($ch, CURLOPT_POSTFIELDS, $data);
  1013. curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
  1014. $info = curl_exec($ch);
  1015. if (curl_errno($ch)) {return 'Errno'.curl_error($ch);}else{ return $info;}
  1016. curl_close($ch);
  1017. }
  1018. public function s_curl($url, $data = '')
  1019. {
  1020. $ch = curl_init();
  1021. curl_setopt($ch, CURLOPT_URL, $url);
  1022. curl_setopt($ch, CURLOPT_CUSTOMREQUEST, "POST");
  1023. curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, false);
  1024. curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, false);
  1025. curl_setopt($ch, CURLOPT_USERAGENT, 'Mozilla/5.0 (compatible; MSIE 5.01; Windows NT 5.0)');
  1026. curl_setopt($ch, CURLOPT_FOLLOWLOCATION, 1);
  1027. curl_setopt($ch, CURLOPT_AUTOREFERER, 1);
  1028. curl_setopt($ch, CURLOPT_POSTFIELDS, $data);
  1029. curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
  1030. $info = curl_exec($ch);
  1031. if (curl_errno($ch)) {
  1032. $info = 'ERROR: ' . curl_error($ch);
  1033. }
  1034. curl_close($ch);
  1035. return $info;
  1036. }
  1037. }