Jjhc.php 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197
  1. <?php
  2. namespace app\job;
  3. use app\common\api\BatchApi;
  4. use app\common\api\TalentLogApi;
  5. use app\common\model\TalentChecklog;
  6. use app\common\state\ProjectState;
  7. use think\queue\Job;
  8. use think\facade\Log;
  9. use think\facade\Db;
  10. use app\common\api\ChuanglanSmsApi;
  11. // 给类文件的命名空间起个别名
  12. use PhpOffice\PhpSpreadsheet\Spreadsheet;
  13. //Xlsx类 保存文件功能类
  14. use PhpOffice\PhpSpreadsheet\Writer\Xlsx;
  15. use app\admin\api\DataApi;
  16. class Jjhc {
  17. public function fire(Job $job, $data) {
  18. if ($this->deal($data)) {
  19. Log::info(json_encode($data));
  20. $job->delete();
  21. return true;
  22. }
  23. Log::error(json_encode($data));
  24. if ($job->attempts() >= 3) {
  25. $job->delete();
  26. return false;
  27. }
  28. $job->release(10); //10秒后重试
  29. }
  30. /**
  31. * 处理业务逻辑
  32. * @param type $data
  33. * @return bool
  34. */
  35. public function deal($data): bool {
  36. switch ($data['type']){
  37. case '1':
  38. $path = dirname(dirname(dirname(__FILE__)));
  39. $spreadsheet = \PhpOffice\PhpSpreadsheet\IOFactory::load($path . "/test.xlsx");
  40. $sheet = $spreadsheet->getSheet(0);
  41. $datas = $sheet->toArray();
  42. $writer = \PhpOffice\PhpSpreadsheet\IOFactory::createWriter($spreadsheet, 'Xlsx');
  43. $dataapi = new DataApi();
  44. for ($index = 0; $index <= count($datas); $index++) {
  45. $cards_list = [];
  46. echo "正在查询第" . ($index + 1) . "人({$datas[$index][1]})的出生日期\r\n";
  47. $info = Db::table('new_talent_info ti')->leftJoin('un_enterprise ue','ti.enterprise_id = ue.id')->where("ue.type = 2 and ti.name = '{$datas[$index][1]}'")->find();
  48. echo "正在查询第" . ($index + 1) . "人({$datas[$index][1]}----{$info['birthday']})的证件号\r\n";
  49. $cards = $dataapi->IDNumber($datas[$index][1],date("Ymd",strtotime($info['birthday'])));
  50. if($cards['code'] == '01' && count($cards['data']) >= 1){
  51. foreach ($cards['data'] as $card){
  52. array_push($cards_list,$card['aac147']);
  53. }
  54. }
  55. array_push($cards_list,$datas[$index][3]);
  56. array_push($cards_list,substr($datas[$index][3],4));
  57. $cards_list = array_unique($cards_list);
  58. foreach ($cards_list as $v){
  59. echo "正在查询第" . ($index + 1) . "人({$v})的失业险\r\n";
  60. $res = $dataapi->queryUnemploymentInsuranceByIdAndTime($v,'202201','202301');
  61. Db::table('data_check_log')->save(['realname' => $datas[$index][1],'card' => $card['aac147'],'params' => json_encode(['card' => $v,'start' => '202201','end' => '202301']), 'result' => json_encode($res),'createTime' => date("Y-m-d H:i:s",time())]);
  62. if($res){
  63. $i = 0;
  64. $months = [];
  65. if(count($res['data']) > 0){
  66. foreach ($res['data'] as $k => $v){
  67. if(strpos($v['AAB069'],"晋华") !== false || strpos($v['AAB069'],"渠梁") !== false){
  68. $i++;
  69. array_push($months,$v['AAE003']);
  70. }
  71. }
  72. sort($months);
  73. $res_str = "2022年共缴费{$i}个月,分别是:".implode('、',$months);
  74. echo "第". ($index + 1) . "失业险整理完毕,姓名:{$datas[$index][1]},".$res_str."\r\n";
  75. $sheet->setCellValue('F' . ($index+1), $res_str);
  76. break;
  77. }
  78. }
  79. echo "第". ($index + 1) . "失业险整理完毕,姓名:{$datas[$index][1]},2022年共缴费0个月\r\n";
  80. $sheet->setCellValue('F' . ($index+1), "2022年共缴费0个月");
  81. sleep(3);
  82. }
  83. }
  84. $writer->save($path . "/test.xlsx");
  85. return false;
  86. break;
  87. case '2':
  88. return false;
  89. $path = dirname(dirname(dirname(__FILE__)));
  90. $spreadsheet = \PhpOffice\PhpSpreadsheet\IOFactory::load($path . "/test.xlsx");
  91. $sheet = $spreadsheet->getSheet(0);
  92. $datas = $sheet->toArray();
  93. $writer = \PhpOffice\PhpSpreadsheet\IOFactory::createWriter($spreadsheet, 'Xlsx');
  94. $dataapi = new DataApi();
  95. for ($index = 0; $index <= count($datas); $index++) {
  96. $cards_list = [];
  97. echo "正在查询第" . ($index + 1) . "人({$datas[$index][1]})的出生日期\r\n";
  98. $info = Db::table('new_talent_info ti')->leftJoin('un_enterprise ue','ti.enterprise_id = ue.id')->where("ue.type = 2 and ti.name = '{$datas[$index][1]}'")->find();
  99. echo "正在查询第" . ($index + 1) . "人({$datas[$index][1]}----{$info['birthday']})的证件号\r\n";
  100. $cards = $dataapi->IDNumber($datas[$index][1],date("Ymd",strtotime($info['birthday'])));
  101. if($cards['code'] == '01' && count($cards['data']) >= 1){
  102. foreach ($cards['data'] as $card){
  103. array_push($cards_list,$card['aac147']);
  104. }
  105. }
  106. array_push($cards_list,$datas[$index][3]);
  107. array_push($cards_list,substr($datas[$index][3],4));
  108. $cards_list = array_unique($cards_list);
  109. foreach ($cards_list as $v){
  110. echo "正在查询第" . ($index + 1) . "人({$v})的养老险\r\n";
  111. $res = $dataapi->queryOldAgeSecurityInsuranceByIdAndTime($v,'202201','202212');
  112. Db::table('data_check_log')->save(['realname' => $datas[$index][1],'card' => $card['aac147'],'params' => json_encode(['card' => $v,'start' => '202201','end' => '202212']), 'result' => json_encode($res),'createTime' => date("Y-m-d H:i:s",time())]);
  113. if($res){
  114. $i = 0;
  115. $months = [];
  116. if(count($res['data']) > 0){
  117. foreach ($res['data'] as $k => $v){
  118. if(strpos($v['AAB004'],"晋华") !== false || strpos($v['AAB004'],"渠梁") !== false){
  119. $i++;
  120. array_push($months,$v['AAE003']);
  121. }
  122. }
  123. sort($months);
  124. $res_str = "2022年共缴费{$i}个月,分别是:".implode('、',$months);
  125. echo "第". ($index + 1) . "养老险整理完毕,姓名:{$datas[$index][1]},".$res_str."\r\n";
  126. $sheet->setCellValue('E' . ($index+1), $res_str);
  127. break;
  128. }
  129. }
  130. echo "第". ($index + 1) . "养老险整理完毕,姓名:{$datas[$index][1]},2022年共缴费0个月\r\n";
  131. $sheet->setCellValue('E' . ($index+1), "2022年共缴费0个月");
  132. sleep(3);
  133. }
  134. }
  135. $writer->save($path . "/test.xlsx");
  136. return false;
  137. break;
  138. case '3':
  139. $path = dirname(dirname(dirname(__FILE__)));
  140. $spreadsheet = \PhpOffice\PhpSpreadsheet\IOFactory::load($path . "/test1.xlsx");
  141. $sheet = $spreadsheet->getSheet(0);
  142. $datas = $sheet->toArray();
  143. $writer = \PhpOffice\PhpSpreadsheet\IOFactory::createWriter($spreadsheet, 'Xlsx');
  144. $dataapi = new DataApi();
  145. for ($index = 0; $index < count($datas); $index++) {
  146. echo "正在查询第" . ($index+1) . "人({$datas[$index][3]})的医保\r\n";
  147. $res = $dataapi->queryJfhbxxByYears($datas[$index][3],$datas[$index][1],'2022');
  148. if($res){
  149. $i = 0;
  150. $months = [];
  151. if(count($res['datalist']) > 0){
  152. foreach ($res['datalist'] as $k => $v){
  153. if( $v['aae140'] == '310'){
  154. $i++;
  155. array_push($months,$v['zmny00']);
  156. }
  157. }
  158. sort($months);
  159. $res_str = "2022年共缴费{$i}个月,分别是:".implode('、',$months);
  160. }else{
  161. $res_str = "2022年共缴费0个月";
  162. }
  163. echo "第". ($index + 1) . "医保整理完毕,姓名:{$datas[$index][1]},".$res_str."\r\n";
  164. $sheet->setCellValue('E' . ($index+1), $res_str);
  165. }
  166. sleep(2);
  167. }
  168. $writer->save($path . "/test1.xlsx");
  169. return false;
  170. break;
  171. case '4':
  172. $path = dirname(dirname(dirname(__FILE__)));
  173. $spreadsheet = \PhpOffice\PhpSpreadsheet\IOFactory::load($path . "/test.xlsx");
  174. $sheet = $spreadsheet->getSheet(0);
  175. $datas = $sheet->toArray();
  176. $writer = \PhpOffice\PhpSpreadsheet\IOFactory::createWriter($spreadsheet, 'Xlsx');
  177. $dataapi = new DataApi();
  178. for ($index = 0; $index < count($datas); $index++) {
  179. echo "正在查询第" . ($index + 1) . "人({$datas[$index][1]})的失信被执行情况\r\n";
  180. $res = $dataapi->untrustworthyPersonnel($datas[$index][2]);
  181. echo "第". ($index + 1) . "人查询,姓名:{$datas[$index][1]},查询结果:{$res['message']}\r\n";
  182. $sheet->setCellValue('D' . ($index+1), $res['message']);
  183. }
  184. $writer->save($path . "/test.xlsx");
  185. return false;
  186. break;
  187. default:
  188. return false;
  189. }
  190. }
  191. }