TaskService.java 2.0 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061
  1. package com.fdkankan.ucenter.task;
  2. import com.fdkankan.common.constant.ConstantFilePath;
  3. import com.fdkankan.common.util.DateUtil;
  4. import com.fdkankan.common.util.FileUtil;
  5. import com.fdkankan.redis.util.RedisUtil;
  6. import com.fdkankan.ucenter.common.RedisKeyUtil;
  7. import com.fdkankan.ucenter.constant.QrCodeFilePath;
  8. import lombok.extern.slf4j.Slf4j;
  9. import org.springframework.beans.factory.annotation.Autowired;
  10. import org.springframework.scheduling.annotation.Scheduled;
  11. import org.springframework.stereotype.Component;
  12. import java.io.File;
  13. import java.util.Arrays;
  14. import java.util.Date;
  15. import java.util.List;
  16. @Component
  17. @Slf4j
  18. public class TaskService {
  19. @Autowired
  20. RedisUtil redisUtil;
  21. @Scheduled(cron = "0 */10 * * * ?")
  22. public void delLoginQrCode(){
  23. long startTime = new Date().getTime();
  24. log.info("delLoginQrCode:开始定时清理本地登录二维码" );
  25. String qrCodePath = QrCodeFilePath.LOGIN_QR_CODE_PATH;
  26. String aliQrCodePath = QrCodeFilePath.ALI_QRCODE_FOLDER;
  27. String wxCodePath = QrCodeFilePath.WEIXIN_QRCODE_FOLDER;
  28. File file = new File(qrCodePath);
  29. File file2 = new File(wxCodePath);
  30. File file3 = new File(aliQrCodePath);
  31. File[] files = file.listFiles();
  32. File[] files1 = file2.listFiles();
  33. File[] files2 = file3.listFiles();
  34. delFile(files);
  35. delFile(files1);
  36. delFile(files2);
  37. log.info("delLoginQrCode:结束定时清理本地登录二维码:耗时{}秒",(new Date().getTime() - startTime)/1000 );
  38. }
  39. private void delFile(File[] files){
  40. if(files == null && files.length >0){
  41. return;
  42. }
  43. for (File f : files) {
  44. if(f==null || !f.getName().contains(".")){
  45. continue;
  46. }
  47. String name = f.getName().substring(0,f.getName().lastIndexOf("."));
  48. if(!redisUtil.hasKey(RedisKeyUtil.QRCODE + name)){
  49. log.info("删除文件:{}",f.getPath());
  50. FileUtil.delFile(f.getPath());
  51. }
  52. }
  53. }
  54. }