opendkqAction.php 3.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133
  1. <?php
  2. /**
  3. * 将数据上传到打卡记录表上
  4. * 请求地址如:http://127.0.0.1/api.php?m=opendkq&openkey=key
  5. * 请求方式:POST
  6. * 提交过来数据[{"name":"姓名","dkdt":"2016-10-22 09:00:00"}]
  7. */
  8. class opendkqClassAction extends openapiAction
  9. {
  10. public function indexAction()
  11. {
  12. //6 接口导入
  13. $carr = $this->senddata(6);
  14. $this->showreturn('成功导入'.$carr['oi'].'条数据');
  15. }
  16. //
  17. private function senddata($type)
  18. {
  19. $str = $this->postdata;
  20. if(isempt($str))$this->showreturn('', 'not data', 201);
  21. $arr = json_decode($str, true);
  22. $oi = 0;$uarr = array();$finarr = array();
  23. $dtobj = c('date');$adb = m('admin');$db = m('kqdkjl');$uobj = m('userinfo');
  24. $updt = '';
  25. $cheobj = c('check');
  26. $snarr = array();
  27. if($type==9){
  28. $snarr = $this->db->getarr('[Q]kqjsn','`pinpai`=1','`id`,`name`','num');
  29. }
  30. $datype = array('密码','指纹','刷卡');
  31. if(is_array($arr))foreach($arr as $k=>$rs){
  32. $name = isset($rs['name']) ? $rs['name'] : '';
  33. $dkdt = isset($rs['dkdt']) ? $rs['dkdt'] : '';
  34. $finge= isset($rs['finge']) ? $rs['finge'] : '';
  35. $name = str_replace("'",'', $name);
  36. $uid = 0;
  37. $snid = 0;
  38. $sntype = 1;
  39. $comid = 0;
  40. $explain = '';
  41. if($type==9){
  42. $sn = arrvalue($rs, 'sn');
  43. if(!$sn)continue;
  44. $snrs = arrvalue($snarr, $sn);
  45. if(!$snrs)continue;
  46. $snid = $snrs['id'];
  47. $explain = '使用['.$snrs['name'].']打卡';
  48. if(!isset($snrs['isgx'])){
  49. m('kqjsn')->update("`lastdt`='$this->now'", $snid);
  50. $snarr[$sn]['isgx'] = 'a';
  51. }
  52. }
  53. if(!isempt($name) && !isempt($dkdt)){
  54. if(!$dtobj->isdate($dkdt))continue;
  55. if($updt=='' || $dkdt>$updt)$updt = $dkdt;
  56. if($type==9 && $finge){
  57. if(isset($finarr[$finge])){
  58. if($finarr[$finge]){
  59. $uid = $finarr[$finge]['id'];
  60. $comid = $finarr[$finge]['companyid'];
  61. }
  62. }else{
  63. $uwher = "`finger`='$finge'";
  64. $usobj = $uobj->getrows($uwher,'`id`,`companyid`');
  65. if($usobj){
  66. $uid = $usobj[0]['id'];
  67. $comid = $usobj[0]['companyid'];
  68. $finarr[$finge] = $usobj[0];
  69. }else{
  70. $finarr[$finge] = false;
  71. }
  72. }
  73. }
  74. if($uid==0){
  75. if(isset($uarr[$name])){
  76. if($uarr[$name]){
  77. $uid = $uarr[$name]['id'];
  78. $comid = $uarr[$name]['companyid'];
  79. }
  80. }else{
  81. $uwher = "`name`='$name'";
  82. if($cheobj->iscnmobile($name))$uwher = "`mobile`='$name'";
  83. if($cheobj->isemail($name))$uwher = "`email`='$name'";
  84. $usar = $adb->getrows($uwher,'`id`,`companyid`');
  85. if($usar){
  86. $uid = $usar[0]['id'];
  87. $comid = $usar[0]['companyid'];
  88. $uarr[$name] = $usar[0];
  89. }else{
  90. $uarr[$name] = false;
  91. }
  92. }
  93. }
  94. if($uid==0)continue;
  95. if($comid==0)$comid = 1;
  96. if($db->rows("`uid`='$uid' and `dkdt`='$dkdt'")>0)continue;
  97. $oi++;
  98. $db->insert(array(
  99. 'uid' => $uid,
  100. 'dkdt' => $dkdt,
  101. 'optdt' => $this->now,
  102. 'type' => $type,
  103. 'snid' => $snid,
  104. 'sntype'=> $sntype,
  105. 'explain'=> $explain,
  106. 'comid'=> $comid,
  107. ));
  108. }
  109. }
  110. if($updt && $updt>$this->now)$updt=$this->now;
  111. //$this->rock->debugs(array($uarr, $finarr),'daorudaka');
  112. return array(
  113. 'oi' => $oi,
  114. 'updt' => $updt,
  115. );
  116. }
  117. /**
  118. * 中控考勤机导入
  119. */
  120. public function zktimeAction()
  121. {
  122. //9中控
  123. $carr = $this->senddata(9);
  124. echo $carr['updt'];
  125. }
  126. }
粤ICP备19079148号