DaKaService.php 6.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202
  1. <?php
  2. /**
  3. * Author: luzheng.liu
  4. * Time: 2019-09-22 16:18
  5. */
  6. namespace app\index\service;
  7. use app\index\model\DakaHoliday;
  8. class DaKaService {
  9. public $data = [
  10. 'ValidYN' => 'Y',
  11. 'AppToken' => 66778899,
  12. 'CardTime' => '2019-09-17+09:04',
  13. 'Address' => '潮州路办公室考勤点',
  14. 'AppID' => 'A|MI+8+SE-9|2.2.4|11584|862860041542790|',
  15. 'StaffID' => '796996',
  16. 'UserID' => '11584',
  17. 'Dimension' => '31.265277',
  18. 'Longitude' => '121.414143',
  19. 'MobileID' => '862860041542790',
  20. 'CardRemarkSZ' => ''
  21. ];
  22. //
  23. // public $dakaInfo = [
  24. // "OrderBy" => "",
  25. // "AppToken" => "66778899",
  26. // 'StaffID' => '796996',
  27. // 'pageSize' => '31',
  28. // 'CardFrom' => '',
  29. // 'DeptID' => '',
  30. // 'EndDate' => '2019-09-11',
  31. // 'pageNum' => '1',
  32. // "CompanyId" => 10,
  33. // 'AppID' => 'A|MI+8+SE-9|2.2.4|11584|862860041542790|192.168.31.25',
  34. // 'BeginDate' => '2019-09-11',
  35. // 'UserID' => '11584',
  36. // 'LangID' => '1',
  37. // ];
  38. public function __construct() {
  39. $date = date('Y-m-d');
  40. $hour = date('H');
  41. list($year, $month, $day) = explode('-', $date);
  42. if ($hour >= 6 && $hour <= 12) {
  43. $min = $day +2;
  44. $this->data['CardTime'] = $date . '+09:' . $min;
  45. $makeTime = "$date 09:$min";
  46. } else {
  47. $min = $day ;
  48. $this->data['CardTime'] = $date . '+19:' . $min;
  49. $makeTime = "$date 19:$min";
  50. }
  51. $cronTime = date('Y-m-d H:i');
  52. if ($cronTime != $makeTime) {
  53. var_dump($cronTime, $makeTime);
  54. die();
  55. }
  56. var_dump("打卡时间" . date('Y-m-d H:i:s'));
  57. }
  58. public function run() {
  59. list($hour, $min, $sec) = explode(':', date('H:i:s'));
  60. $date = date('Y-m-d');
  61. list($year, $month, $day) = explode('-', $date);
  62. $isHoliday = $this->getHoliday($year, (int)$month);
  63. if ($isHoliday) {
  64. var_dump($date . "这天是假期不打卡,退出");
  65. die();
  66. }
  67. var_dump($date . "正常上班");
  68. if ($hour >= 6 && $hour <= 12) {
  69. var_dump($date . "上班,打卡");
  70. } else {
  71. var_dump($date . "下班,打卡");
  72. }
  73. $this->data['AppID'] .= '192.168.1.'.random_int(1, 200);
  74. $this->curlDaka($this->data);
  75. }
  76. //获取当月假期
  77. public function getHoliday($year, $month) {
  78. $holidayModel = new DakaHoliday();
  79. $holidayListByDb = $holidayModel::where(['request_date' => date('Y-m')])->column('holiday');
  80. if (!empty($holidayListByDb)) {
  81. if (in_array(date('Y-m-d'), $holidayListByDb)) {
  82. var_dump(date('Y-m-d') . "这天是假期不打卡,退出");
  83. return true;
  84. }
  85. var_dump(date('Y-m-d') . "正常上班");
  86. return false;
  87. }
  88. $holidayFlag = false;
  89. $returnInfo = file_get_contents("http://v.juhe.cn/calendar/month?year-month={$year}-{$month}&key=3384938f081a4a6338dcc11fdb66252f");
  90. $data = json_decode($returnInfo, true);
  91. if ($data['error_code'] !== 0) {
  92. var_dump("请求假期接口失败--{$returnInfo}");
  93. die();
  94. }
  95. $insertData = [];
  96. $holidayList = array_column($data['result']['data']['holiday_array'], 'list');
  97. $holidayList = array_merge(...$holidayList);
  98. foreach ($holidayList as $k => $v) {
  99. if ($v['status'] != 1) {
  100. continue;
  101. }
  102. $date = date('Y-m-d', strtotime($v['date']));
  103. if ($date === date('Y-m-d')) {
  104. $holidayFlag = true;
  105. }
  106. $insertData[] = [
  107. 'holiday' => date('Y-m-d', strtotime($v['date'])),
  108. 'request_date' => date('Y-m')
  109. ];
  110. }
  111. $holidayModel->insertAll($insertData, true);
  112. return $holidayFlag;
  113. }
  114. function curlDaka($data) {
  115. $data = http_build_query($data);
  116. $curl = curl_init();
  117. curl_setopt_array($curl, [
  118. CURLOPT_PORT => "1001",
  119. CURLOPT_URL => "http://hr.baodao.com.cn:1001/AppWebService/GhrApp.asmx/InsertStaffCardRecord",
  120. CURLOPT_RETURNTRANSFER => true,
  121. CURLOPT_ENCODING => "",
  122. CURLOPT_MAXREDIRS => 10,
  123. CURLOPT_TIMEOUT => 30,
  124. CURLOPT_HTTP_VERSION => CURL_HTTP_VERSION_1_1,
  125. CURLOPT_CUSTOMREQUEST => "POST",
  126. CURLOPT_POSTFIELDS => $data,
  127. CURLOPT_HTTPHEADER => [
  128. "Content-Type: application/x-www-form-urlencoded",
  129. "cache-control: no-cache"
  130. ],
  131. ]);
  132. $response = curl_exec($curl);
  133. $err = curl_error($curl);
  134. curl_close($curl);
  135. if ($err) {
  136. echo "cURL Error #:" . $err."\n";
  137. die();
  138. }
  139. echo $response."\n";
  140. }
  141. public function curlDakaInfo($data) {
  142. $data = http_build_query($data);
  143. $curl = curl_init();
  144. curl_setopt_array($curl, [
  145. CURLOPT_PORT => "1001",
  146. CURLOPT_URL => "http://hr.baodao.com.cn:1001/AppWebService/GhrApp.asmx/GetStaffCardRecordPeyDay",
  147. CURLOPT_RETURNTRANSFER => true,
  148. CURLOPT_ENCODING => "",
  149. CURLOPT_MAXREDIRS => 10,
  150. CURLOPT_TIMEOUT => 30,
  151. CURLOPT_HTTP_VERSION => CURL_HTTP_VERSION_1_1,
  152. CURLOPT_CUSTOMREQUEST => "POST",
  153. CURLOPT_POSTFIELDS => $data,
  154. CURLOPT_HTTPHEADER => [
  155. "Accept: */*",
  156. "Accept-Encoding: gzip, deflate",
  157. "Cache-Control: no-cache",
  158. "Connection: keep-alive",
  159. "Content-Type: application/x-www-form-urlencoded",
  160. "Host: hr.baodao.com.cn:1001",
  161. "cache-control: no-cache"
  162. ],
  163. ]);
  164. $response = curl_exec($curl);
  165. $err = curl_error($curl);
  166. curl_close($curl);
  167. if ($err) {
  168. echo "cURL Error #:" . $err . "\n";
  169. die();
  170. }
  171. return $response;
  172. }
  173. }