Order.php.bak1 43 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829
  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. Log::record('xinshuibiaozhi'.':'.$getdata["service"]['data']['data']);
  271. $data3 = array();
  272. $data3['device_id'] = $device["device_id"];
  273. $data3['port'] = 'tp_water_pressure';
  274. $data3['storeTime'] = date('Y-m-d H:i:s');
  275. $data3['batteyValue'] = dechex($getdata["service"]['data']["battery"]);
  276. $data3['unit'] =$getdata["service"]['data']['data'];
  277. $data3['address'] = '180.101.147.89';
  278. $data3['alarmBoolean'] = $getdata["service"]['data']["alarm"];
  279. $alarm=dechex($data3['alarmBoolean']);
  280. $data3['sign'] = round($getdata["service"]['data']["signal"]/6);
  281. $data3['coeffice'] = dechex($getdata["service"]['data']["coeffice"]);
  282. if ($data3['alarmBoolean']!== 0){
  283. if ($data3['alarmBoolean']== 161){
  284. $data3['data1']='WP1';
  285. }else{
  286. $data3['data1']='WP2';
  287. }
  288. }else {
  289. $data3['data1'] = 'WP0';
  290. }
  291. switch ($data3['coeffice']){
  292. case 'd3':
  293. $data3['data4'] = $data3['unit']*0.001;
  294. break;
  295. case 'd2':
  296. $data3['data4'] = $data3['unit']*0.01;
  297. break;
  298. case 'd1':
  299. $data3['data4'] = $data3['unit']*0.1;
  300. break;
  301. case 'e0':
  302. $data3['data4'] = $data3['unit'];
  303. break;
  304. case 'e1':
  305. $data3['data4'] = $data3['unit']*10;
  306. break;
  307. case 'e2':
  308. $data3['data4'] = $data3['unit']*100;
  309. break;
  310. }
  311. $sql = "INSERT INTO sp_d{$data3['device_id']} VALUES ('','{$data3['device_id']}','{$data3['port']}','{$data3['storeTime']}',
  312. '','','','{$data3['data1']}','{$data3['batteyValue']}','{$data3['sign']}','{$data3['data4']}','11111111111')";
  313. $res5 = addDataInfo($sql);
  314. if ($data3['alarmBoolean']!== 0){
  315. $sql = "INSERT INTO sp_sj2017 VALUES ('','tp_water_pressure','{$data3['device_id']}','{$data3['storeTime']}','$alarm','{$data3['address']}', ''
  316. ,'{$data3['data1']}','{$data3['batteyValue']}','{$data3['sign']}','{$data3['data4']}','','','','','','','','','','')";
  317. $insert_id = addDataInfo($sql);
  318. // $sql66="update sp_devices_status set statustime=".$data3['storeTime'];
  319. // Log::record('sql66'.':'.$sql66);
  320. // $update_id = addDataInfo($sql66);
  321. if ($data3['alarmBoolean']== 161){
  322. $msg['evt'] = "WP1";
  323. $msg['msg'] = "低压";
  324. }else{ // high
  325. $msg['evt'] = "WP2";
  326. $msg['msg'] = "高压";
  327. }
  328. if ( $msg['evt']=='WP1' || $msg['evt']=='WP2' ) {
  329. $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"]}'";
  330. $company = add($sql3);
  331. $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%'";
  332. $union_sql=add($sql4);
  333. Log::record('sql12345'.':'.$sql4);
  334. $openids=$this->array_column1($union_sql,"phone");
  335. if (empty($openids))
  336. {
  337. echo 'open is null';
  338. exit;
  339. }
  340. // Log::record('data666_phone'.':'.$openids);
  341. $sql5="SELECT openid FROM sp_wx_customuser WHERE type='wx' and idphone in($openids)";
  342. $op=add($sql5);
  343. $access_token=GetAccess_Token();
  344. $address='警报地址:'.$company[0]['owner_address'].$company[0]['unitinfo'];
  345. $deviceid=$device["device_id"];
  346. $type=$msg['msg'];
  347. $time=$data3['storeTime'];
  348. $remark='设备名称:'.$company[0]['owner_name'];
  349. $url_wx_push2 = "http://www.jd-ioe.com/jdxf/wxapp2.php/Home/Waterwarn/message_water";
  350. Log::record('data666_url_wx_push2'.':'. $url_wx_push2);
  351. $data666['IMEI']=$device["device_id"];
  352. Log::record('data666_IMET'.':'.$data666['IMEI']);
  353. $data666['phone']=$openids;
  354. Log::record('data666_phone'.':'.$data666['phone']);
  355. $data666['evt']=$data3['data1'];
  356. Log::record('data666_evt'.':'.$data666['evt']);
  357. // Log::record('data666'.':'.$data666);
  358. $this->curl($url_wx_push2,$data666);
  359. // $url_wx_push2 = "http://www.jd-ioe.com/jdxf/wxapp2.php/Home/Waterwarn/bj";
  360. foreach($op as $key => $o){
  361. if (!empty($o['openid']))
  362. {
  363. // $data88['openid']=$o['openid'];
  364. // $data88['address']=$address;
  365. // $data88['deviceid']=$deviceid;
  366. // $data88['type']=$type;
  367. // $data88['time']=$time;
  368. // $data88['remark']=$remark;
  369. //token,微信id,地址,设备号,类型,时间,设备名称(或者其他内容)
  370. //{{first.DATA}}$address
  371. //设备号:{{keyword1.DATA}}$deviceid
  372. //报警类型:{{keyword2.DATA}}$type
  373. //时间:{{keyword3.DATA}}$time
  374. //{{remark.DATA}}$remark
  375. $Message=$this->SendDeviceAlarm($access_token,$o['openid'],$address,$deviceid,$type,$time,$remark,$url='');
  376. // s_curl($url_wx_push2,$data88);
  377. $Message['openid']=$o['openid'];
  378. $arr[$key]=$Message;
  379. }
  380. }
  381. }
  382. }
  383. }
  384. if ($device['deviceType']=='Smoke') {
  385. if ($getdata["service"]['data']["DeviceStatus"]!== 7){
  386. $arr_bit = array(
  387. "","报警","报警静音","保留","低压","故障","保留"
  388. );
  389. $deviceStatus=$getdata["service"]['data']["DeviceStatus"];
  390. $data3 = array();
  391. $data3['device_code'] = $device["device_id"];
  392. $data3['time'] = date('Y-m-d H:i:s');
  393. $data3['status'] = 'y'.'0'.$deviceStatus;
  394. $data3['address'] = '180.101.147.89';
  395. $data3['compartment'] = '';
  396. $data3['fireprocess'] = '';
  397. $data3['flowendtime'] = '0000-00-00 00:00:00';
  398. $data3['ncmd'] = 'y'.'0'.$deviceStatus;
  399. $data3['data1'] = 'y'.'0'.$deviceStatus;
  400. $data3['data2'] = $arr_bit["{$deviceStatus}"];
  401. $data3['data3'] = '';
  402. $data3['data4'] = '烟雾'.$arr_bit["{$deviceStatus}"];
  403. $data3['data5'] = '';
  404. $sql = "INSERT INTO sp_hj2017 VALUES ('','','{$data3['device_code']}','{$data3['time']}','{$data3['status']}','{$data3['address']}','{$data3['compartment']}',
  405. '{$data3['fireprocess']}', '{$data3['flowendtime']}', '{$data3['ncmd']}','{$data3['data1']}','{$data3['data2']}','{$data3['data3']}','{$data3['data4']}','{$data3['data5']}','','',''
  406. ,'','','','','','')";
  407. $res5 = addDataInfo($sql);
  408. // $sql66="update sp_devices_status set statustime=".$data3['time'];
  409. // Log::record('sql66'.':'.$sql66);
  410. // $update_id = addDataInfo($sql66);
  411. }
  412. $arr_h=array(1,2);
  413. if (in_array($getdata["service"]['data']["DeviceStatus"],$arr_h)){
  414. $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"]}'";
  415. Log::record('sql3'.':'.$sql3);
  416. $company = add($sql3);
  417. Log::record('company'.':'.$company[0]['company']);
  418. $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%'";
  419. Log::record('sql4'.':'.$sql4);
  420. $union_sql=add($sql4);
  421. $openids=$this->array_column1($union_sql,"phone");
  422. if (empty($openids))
  423. {
  424. echo 'open is null';
  425. exit;
  426. }
  427. $sql5="SELECT openid FROM sp_wx_customuser WHERE type='wx' and idphone in($openids)";
  428. $op=add($sql5);
  429. $access_token=GetAccess_Token();
  430. $address='警报地址:'.$company[0]['owner_address'].$company[0]['unitinfo'];
  431. $deviceid=$device["device_id"];
  432. $type='烟雾';
  433. $time=$data3['time'];
  434. $remark='设备名称:'.$company[0]['owner_name'];
  435. $url_wx_push2 = "http://www.jd-ioe.com/jdxf/wxapp2.php/Home/Waterwarn/bj";
  436. Log::record('data666_url_wx_push2'.':'.$url_wx_push2);
  437. $data666['phone']=$openids;
  438. Log::record('data666_phone'.':'.$data666['phone']);
  439. $data666['IMEI']=$device["device_id"];
  440. Log::record('data666_IMEI'.':'.$data666['IMEI']);
  441. $data666['time']=$data3['time'];
  442. Log::record('data666_time'.':'.$data666['time']);
  443. $data666['evt']=$data3['data1'];
  444. Log::record('data666_evt'.':'.$data666['evt']);
  445. $this->curl($url_wx_push2,$data666);
  446. foreach($op as $key => $o){
  447. if (!empty($o['openid']))
  448. {
  449. // $data88['openid']=$o['openid'];
  450. // $data88['address']=$address;
  451. // $data88['deviceid']=$deviceid;
  452. // $data88['type']=$type;
  453. // $data88['time']=$time;
  454. // $data88['remark']=$remark;
  455. //token,微信id,地址,设备号,类型,时间,设备名称(或者其他内容)
  456. //{{first.DATA}}$address
  457. //设备号:{{keyword1.DATA}}$deviceid
  458. //报警类型:{{keyword2.DATA}}$type
  459. //时间:{{keyword3.DATA}}$time
  460. //{{remark.DATA}}$remark
  461. $Message=$this->SendDeviceAlarm($access_token,$o['openid'],$address,$deviceid,$type,$time,$remark,$url='');
  462. // s_curl($url_wx_push2,$data88);
  463. $Message['openid']=$o['openid'];
  464. $arr[$key]=$Message;
  465. }
  466. }
  467. }
  468. } elseif($device['deviceType']=='MultiSensor') {
  469. if($getdata["service"]['data']["alarmBoolean"]== 17){
  470. // $sql1="SELECT * from 'dev_' . {$device["device_id"]} where addtime=(select max(addtime) from 'dev_' . {$device["device_id"]})";
  471. // $Model = M();
  472. // $result = $Model->query($sql1);
  473. // $service=json_decode($result['']['service']);
  474. $unit=dechex($getdata["service"]['data']["unit"]);
  475. $data3 = array();
  476. $data3['device_code'] = $device["device_id"];
  477. $data3['time'] = date('Y-m-d H:i:s');
  478. $data3['status'] = $getdata["service"]['data']["alarmBoolean"];
  479. $data3['address'] = '180.101.147.89';
  480. $data3['ncmd'] = '';
  481. $arr_y=array('10','11','20','21','22');
  482. $sql11="SELECT dwtype FROM sp_owner WHERE owner_code ='{$device["device_id"]}'";
  483. $dwtype = add($sql11);
  484. if ($dwtype[0]['dwtype'] == 5){
  485. if ($data3['unit']== 1){
  486. $data3['data1']='LL2';
  487. }elseif($data3['unit']== 2){
  488. $data3['data1']='LL1';
  489. }else{
  490. $data3['data1']='LL0';
  491. }
  492. }else {
  493. if ($data3['unit']== 1){
  494. $data3['data1']='WP2';
  495. }elseif($data3['unit']== 2){
  496. $data3['data1']='WP1';
  497. }else{
  498. $data3['data1']='WP0';
  499. }
  500. }
  501. $data3['data2'] = $getdata["service"]['data']["batteyValue"];
  502. $data3['data3'] = '';
  503. switch ($unit){
  504. case '10':
  505. $data3['data4'] = $getdata["service"]['data']["data"]*0.0001;
  506. break;
  507. case '11':
  508. $data3['data4'] = $getdata["service"]['data']["data"]*0.001;
  509. break;
  510. case '20':
  511. $data3['data4'] = $getdata["service"]['data']["data"]*0.01;
  512. break;
  513. case '21':
  514. $data3['data4'] = $getdata["service"]['data']["data"]*0.1;
  515. break;
  516. case '22':
  517. $data3['data4'] = $getdata["service"]['data']["data"];
  518. break;
  519. case '30':
  520. $data3['data4'] = $getdata["service"]['data']["data"]*0.0000001;
  521. break;
  522. case '31':
  523. $data3['data4'] = $getdata["service"]['data']["data"]*0.000001;
  524. break;
  525. case '40':
  526. $data3['data4'] = $getdata["service"]['data']["data"]*0.00001;
  527. break;
  528. case '41':
  529. $data3['data4'] = $getdata["service"]['data']["data"]*0.0001;
  530. break;
  531. case '42':
  532. $data3['data4'] = $getdata["service"]['data']["data"]*0.001;
  533. break;
  534. case '50':
  535. $data3['data4'] = $getdata["service"]['data']["data"]*0.01;
  536. break;
  537. case '51':
  538. $data3['data4'] = $getdata["service"]['data']["data"]*0.1;
  539. break;
  540. case '52':
  541. $data3['data4'] = $getdata["service"]['data']["data"];
  542. break;
  543. case '2':
  544. $data3['data4'] = $getdata["service"]['data']["data"]*0.001;
  545. break;
  546. }
  547. $data3['data5'] = '';
  548. $sql = "INSERT INTO sp_sj2017 VALUES ('','tp_water_pressure','{$data3['device_code']}','{$data3['time']}','{$data3['status']}','{$data3['address']}', '{$data3['ncmd']}'
  549. ,'{$data3['data1']}','{$data3['data2']}','{$data3['data3']}','{$data3['data4']}','{$data3['data5']}','','','','','','','','','')";
  550. // Log::record('sql123'.':'.$sql);
  551. $insert_id = addDataInfo($sql);
  552. if ($dwtype[0]['dwtype'] == 5) {
  553. if ($getdata["service"]['data']["unit"] == '1') {
  554. $msg['evt'] = "WP2";
  555. $msg['msg'] = "高水位";
  556. } elseif ($getdata["service"]['data']["unit"] == '2') { // high
  557. $msg['evt'] = "WP1";
  558. $msg['msg'] = "低水位";
  559. }
  560. }else{
  561. if ($getdata["service"]['data']["unit"] == '1') {
  562. $msg['evt'] = "WP2";
  563. $msg['msg'] = "高压";
  564. } elseif ($getdata["service"]['data']["unit"] == '2') { // high
  565. $msg['evt'] = "WP1";
  566. $msg['msg'] = "低压";
  567. }
  568. }
  569. if ( $msg['evt']=='WP1' || $msg['evt']=='WP2' ) {
  570. $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"]}'";
  571. $company = add($sql3);
  572. $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%'";
  573. $union_sql=add($sql4);
  574. Log::record('sql12345'.':'.$sql4);
  575. $openids=$this->array_column1($union_sql,"phone");
  576. if (empty($openids))
  577. {
  578. echo 'open is null';
  579. exit;
  580. }
  581. Log::record('data666_phone'.':'.$openids);
  582. $sql5="SELECT openid FROM sp_wx_customuser WHERE type='wx' and idphone in($openids)";
  583. $op=add($sql5);
  584. $access_token=GetAccess_Token();
  585. $address='警报地址:'.$company[0]['owner_address'].$company[0]['unitinfo'];
  586. $deviceid=$device["device_id"];
  587. $type=$msg['msg'];
  588. $time=$data3['time'];
  589. $remark='设备名称:'.$company[0]['owner_name'];
  590. //
  591. $url_wx_push2 = "http://www.jd-ioe.com/jdxf/wxapp2.php/Home/Waterwarn/message_water";
  592. Log::record('data666_url_wx_push2'.':'. $url_wx_push2);
  593. $data666['IMEI']=$device["device_id"];
  594. Log::record('data666_IMET'.':'.$data666['IMEI']);
  595. $data666['phone']=$openids;
  596. Log::record('data666_phone'.':'.$data666['phone']);
  597. $data666['evt']=$data3['data1'];
  598. Log::record('data666_evt'.':'.$data666['evt']);
  599. // Log::record('data666'.':'.$data666);
  600. $this->curl($url_wx_push2,$data666);
  601. // $url_wx_push2 = "http://www.jd-ioe.com/jdxf/wxapp2.php/Home/Waterwarn/bj";
  602. foreach($op as $key => $o){
  603. if (!empty($o['openid']))
  604. {
  605. // $data88['openid']=$o['openid'];
  606. // $data88['address']=$address;
  607. // $data88['deviceid']=$deviceid;
  608. // $data88['type']=$type;
  609. // $data88['time']=$time;
  610. // $data88['remark']=$remark;
  611. //token,微信id,地址,设备号,类型,时间,设备名称(或者其他内容)
  612. //{{first.DATA}}$address
  613. //设备号:{{keyword1.DATA}}$deviceid
  614. //报警类型:{{keyword2.DATA}}$type
  615. //时间:{{keyword3.DATA}}$time
  616. //{{remark.DATA}}$remark
  617. $Message=$this->SendDeviceAlarm($access_token,$o['openid'],$address,$deviceid,$type,$time,$remark,$url='');
  618. // s_curl($url_wx_push2,$data88);
  619. $Message['openid']=$o['openid'];
  620. $arr[$key]=$Message;
  621. }
  622. }
  623. }
  624. }
  625. }
  626. }
  627. return json_encode($data, 320);
  628. }
  629. }
  630. public function testdata1(){
  631. $rand=rand(0,2);
  632. $data=[
  633. '{"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"}}',
  634. '{"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"}}',
  635. '{"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"}}',
  636. ];
  637. $header=["Content-Type:application/json"];
  638. //将数据分配给不同的服务
  639. $httpserver=["http://47.98.153.212:1101","http://47.98.153.212:1102","http://47.98.153.212:1103"];
  640. $senddata=$data[$rand];
  641. $server=$httpserver[$rand];
  642. $res=curltest($server,$senddata,$header);
  643. dump($res);
  644. /* //设备所属公司
  645. $owner=Db::name('device')->field("owner_id")->where('iot_id',$iot_id)->find();
  646. $ownerhost=Db::name('owner')->where('id',$owner["owner_id"])->find();
  647. $ipaddr=$ownerhost['host'].":".$ownerhost['port'];
  648. $res=curltest($ipaddr,$senddata);
  649. dump($res);*/
  650. //将数据转发到不同的接口中
  651. /* $sendapi="senddata".$rand;
  652. echo $this->$sendapi($data[$rand],$devies[$rand]);*/
  653. }
  654. public function senddata0($data){
  655. //将数据存到总表
  656. //将数据存到设备详细表
  657. //查看当前设备属于哪家业主
  658. //查找业主的服务器
  659. //给服务器发数据
  660. }
  661. public function senddata1($data){
  662. echo "m2".$data;
  663. }
  664. public function senddata2($data){
  665. echo "m3".$data;
  666. }
  667. public function array_column1($rows, $column_key, $index_key = null) {
  668. $data = array();
  669. if (empty($index_key)) {
  670. foreach ($rows as $row) {
  671. $data[] = $row[$column_key];
  672. }
  673. $data=implode(",",$data);
  674. } else {
  675. foreach ($rows as $row) {
  676. $data[$row[$index_key]] = $row[$column_key];
  677. }
  678. }
  679. return $data;
  680. }
  681. public function SendDeviceAlarm($access_token,$openid,$address,$deviceid,$type,$time,$remark,$url){
  682. $data = array(
  683. "touser"=> $openid,
  684. "template_id"=>"JkQYUiScfIuH9O4vvUgtgYxPIOBOY7Zh9w2DcWTgm50",
  685. //"url" =>"http://zt-iot.com/ztxf/weixin.php/Home/Fire/water",
  686. "data"=> array(
  687. "first"=> array(
  688. "value"=> $address,
  689. "color"=>"#44b549"
  690. ),
  691. "keyword1"=>array(
  692. "value"=> $deviceid,
  693. "color"=>"#173177"
  694. ),
  695. "keyword2"=> array(
  696. "value"=> $type,
  697. "color"=>"#173177"
  698. ),
  699. "keyword3"=> array(
  700. "value"=> $time,
  701. "color"=>"#173177"
  702. ),
  703. "remark"=>array(
  704. "value"=> $remark,
  705. "color"=>"#aaaaaa"
  706. )
  707. )
  708. );
  709. //{{first.DATA}}
  710. //设备号:{{keyword1.DATA}}
  711. //报警类型:{{keyword2.DATA}}
  712. //时间:{{keyword3.DATA}}
  713. //{{remark.DATA}}
  714. $data = json_encode($data);
  715. $QUEST_URL = "https://api.weixin.qq.com/cgi-bin/message/template/send?access_token=".$access_token;
  716. $res = $this->curl($QUEST_URL,$data);
  717. return json_decode($res,true);
  718. }
  719. public function curl($url,$data=''){
  720. $ch = curl_init();
  721. curl_setopt($ch, CURLOPT_URL, $url);
  722. curl_setopt($ch, CURLOPT_CUSTOMREQUEST, "POST");
  723. curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, FALSE);
  724. curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, FALSE);
  725. curl_setopt($ch, CURLOPT_USERAGENT, 'Mozilla/5.0 (compatible; MSIE 5.01; Windows NT 5.0)');
  726. curl_setopt($ch, CURLOPT_FOLLOWLOCATION, 1);
  727. curl_setopt($ch, CURLOPT_AUTOREFERER, 1);
  728. curl_setopt($ch, CURLOPT_POSTFIELDS, $data);
  729. curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
  730. $info = curl_exec($ch);
  731. if (curl_errno($ch)) {return 'Errno'.curl_error($ch);}else{ return $info;}
  732. curl_close($ch);
  733. }
  734. public function s_curl($url, $data = '')
  735. {
  736. $ch = curl_init();
  737. curl_setopt($ch, CURLOPT_URL, $url);
  738. curl_setopt($ch, CURLOPT_CUSTOMREQUEST, "POST");
  739. curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, false);
  740. curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, false);
  741. curl_setopt($ch, CURLOPT_USERAGENT, 'Mozilla/5.0 (compatible; MSIE 5.01; Windows NT 5.0)');
  742. curl_setopt($ch, CURLOPT_FOLLOWLOCATION, 1);
  743. curl_setopt($ch, CURLOPT_AUTOREFERER, 1);
  744. curl_setopt($ch, CURLOPT_POSTFIELDS, $data);
  745. curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
  746. $info = curl_exec($ch);
  747. if (curl_errno($ch)) {
  748. $info = 'ERROR: ' . curl_error($ch);
  749. }
  750. curl_close($ch);
  751. return $info;
  752. }
  753. }