DaKaService.php 6.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201
  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. die();
  54. }
  55. var_dump("打卡时间" . date('Y-m-d H:i:s'));
  56. }
  57. public function run() {
  58. list($hour, $min, $sec) = explode(':', date('H:i:s'));
  59. $date = date('Y-m-d');
  60. list($year, $month, $day) = explode('-', $date);
  61. $isHoliday = $this->getHoliday($year, (int)$month);
  62. if ($isHoliday) {
  63. var_dump($date . "这天是假期不打卡,退出");
  64. die();
  65. }
  66. var_dump($date . "正常上班");
  67. if ($hour >= 6 && $hour <= 12) {
  68. var_dump($date . "上班,打卡");
  69. } else {
  70. var_dump($date . "下班,打卡");
  71. }
  72. $this->data['AppID'] .= '192.168.1.'.random_int(1, 200);
  73. $this->curlDaka($this->data);
  74. }
  75. //获取当月假期
  76. public function getHoliday($year, $month) {
  77. $holidayModel = new DakaHoliday();
  78. $holidayListByDb = $holidayModel::where(['request_date' => date('Y-m')])->column('holiday');
  79. if (!empty($holidayListByDb)) {
  80. if (in_array(date('Y-m-d'), $holidayListByDb)) {
  81. var_dump(date('Y-m-d') . "这天是假期不打卡,退出");
  82. return true;
  83. }
  84. var_dump(date('Y-m-d') . "正常上班");
  85. return false;
  86. }
  87. $holidayFlag = false;
  88. $returnInfo = file_get_contents("http://v.juhe.cn/calendar/month?year-month={$year}-{$month}&key=3384938f081a4a6338dcc11fdb66252f");
  89. $data = json_decode($returnInfo, true);
  90. if ($data['error_code'] !== 0) {
  91. var_dump("请求假期接口失败--{$returnInfo}");
  92. die();
  93. }
  94. $insertData = [];
  95. $holidayList = array_column($data['result']['data']['holiday_array'], 'list');
  96. $holidayList = array_merge(...$holidayList);
  97. foreach ($holidayList as $k => $v) {
  98. if ($v['status'] != 1) {
  99. continue;
  100. }
  101. $date = date('Y-m-d', strtotime($v['date']));
  102. if ($date === date('Y-m-d')) {
  103. $holidayFlag = true;
  104. }
  105. $insertData[] = [
  106. 'holiday' => date('Y-m-d', strtotime($v['date'])),
  107. 'request_date' => date('Y-m')
  108. ];
  109. }
  110. $holidayModel->insertAll($insertData, true);
  111. return $holidayFlag;
  112. }
  113. function curlDaka($data) {
  114. $data = http_build_query($data);
  115. $curl = curl_init();
  116. curl_setopt_array($curl, [
  117. CURLOPT_PORT => "1001",
  118. CURLOPT_URL => "http://hr.baodao.com.cn:1001/AppWebService/GhrApp.asmx/InsertStaffCardRecord",
  119. CURLOPT_RETURNTRANSFER => true,
  120. CURLOPT_ENCODING => "",
  121. CURLOPT_MAXREDIRS => 10,
  122. CURLOPT_TIMEOUT => 30,
  123. CURLOPT_HTTP_VERSION => CURL_HTTP_VERSION_1_1,
  124. CURLOPT_CUSTOMREQUEST => "POST",
  125. CURLOPT_POSTFIELDS => $data,
  126. CURLOPT_HTTPHEADER => [
  127. "Content-Type: application/x-www-form-urlencoded",
  128. "cache-control: no-cache"
  129. ],
  130. ]);
  131. $response = curl_exec($curl);
  132. $err = curl_error($curl);
  133. curl_close($curl);
  134. if ($err) {
  135. echo "cURL Error #:" . $err."\n";
  136. die();
  137. }
  138. echo $response."\n";
  139. }
  140. public function curlDakaInfo($data) {
  141. $data = http_build_query($data);
  142. $curl = curl_init();
  143. curl_setopt_array($curl, [
  144. CURLOPT_PORT => "1001",
  145. CURLOPT_URL => "http://hr.baodao.com.cn:1001/AppWebService/GhrApp.asmx/GetStaffCardRecordPeyDay",
  146. CURLOPT_RETURNTRANSFER => true,
  147. CURLOPT_ENCODING => "",
  148. CURLOPT_MAXREDIRS => 10,
  149. CURLOPT_TIMEOUT => 30,
  150. CURLOPT_HTTP_VERSION => CURL_HTTP_VERSION_1_1,
  151. CURLOPT_CUSTOMREQUEST => "POST",
  152. CURLOPT_POSTFIELDS => $data,
  153. CURLOPT_HTTPHEADER => [
  154. "Accept: */*",
  155. "Accept-Encoding: gzip, deflate",
  156. "Cache-Control: no-cache",
  157. "Connection: keep-alive",
  158. "Content-Type: application/x-www-form-urlencoded",
  159. "Host: hr.baodao.com.cn:1001",
  160. "cache-control: no-cache"
  161. ],
  162. ]);
  163. $response = curl_exec($curl);
  164. $err = curl_error($curl);
  165. curl_close($curl);
  166. if ($err) {
  167. echo "cURL Error #:" . $err . "\n";
  168. die();
  169. }
  170. return $response;
  171. }
  172. }