智慧保安后台管理-外网-验收版本
tangzy
2021-12-06 cc057177b2fb17aee9a173a6adbabdc578fd74c7
src/main/java/org/springblade/modules/FTP/monitor.java
@@ -10,25 +10,12 @@
import java.io.IOException;
import java.io.InputStream;
import static org.springblade.common.constant.FtpConstant.*;
@Component
public class monitor {
   //ftp服务器IP地址
   private static String ftpHost = "192.168.0.105";
   //ftp服务器端口
   private static int ftpPort = 21;
   //ftp服务器用户名
   private static String ftpUserName = "yly";
   //ftp服务器密码
   private static String ftpPassword = "Yly@123";
   //ftp服务器路径
   private static String ftpPath = "anbao/";
   //本地路径
   private static String localPath = "D:\\anbao";
   //文件名
   //private static String fileName = "nsql.json";
   @Scheduled(cron = "*/30 * * * * ?")
   //@Scheduled(cron = "*/30 * * * * ?")
   public static boolean isFTPFileExist() {
      FTPClient ftp = new FTPClient();
@@ -37,7 +24,7 @@
         // 连接ftp服务器
         ftp.connect(ftpHost, ftpPort);
         ftp.connect(ftpHost_dev, ftpPort);
         // 登陆
@@ -76,41 +63,49 @@
         //ftp.changeWorkingDirectory(new String(dir.getBytes("GBK"), FTP.DEFAULT_CONTROL_ENCODING));
         // 检验文件是否存在
         ftp.changeWorkingDirectory(ftpPath);
         FTPFile[] files = ftp.listFiles();
         if (files.length==0){
            return false;
         }
         for (FTPFile file : files){
            String fileName = file.getName();
            //把文件下载到本地
            FtpUtil.downloadFtpFile(ftpHost, ftpUserName, ftpPassword, ftpPort, ftpPath, localPath, fileName);
            //
            String s = OutJson.TestJson(fileName);
            //sql语句
            String sql = OutJson.stringReplace(s);
            String[] split = sql.split(";");//以逗号分割
            for (String sqls : split) {
               //判断是否是新增,删除,修改
               String substring = sqls.substring(0, 2);
               //新增
               if (substring.equals("in")) {
                  //运行sql语句
                  MysqlCenlint.inster(sqls);
               }
               //修改
               else if (substring.equals("up")) {
                  MysqlCenlint.update(sqls);
               }
               //删除
               else {
                  MysqlCenlint.delete(sqls);
         else {
            for (FTPFile file : files){
               String fileName = file.getName();
               InputStream is = ftp.retrieveFileStream(new String(fileName.getBytes("GBK"), FTP.DEFAULT_CONTROL_ENCODING));
               String substring1 = fileName.substring(0, 1);
               if (substring1.equals("n")){
                  //把文件下载到本地
                  FtpUtil.downloadFtpFile(ftpHost_dev, ftpUserName, ftpPassword, ftpPort, ftpPath, localPath, fileName);
                  //
                  String s = OutJson.TestJson(fileName);
                  //sql语句
                  String sql = OutJson.stringReplace(s);
                  String[] split = sql.split(";");//以逗号分割
                  for (String sqls : split) {
                     //判断是否是新增,删除,修改
                     String substring = sqls.substring(0, 2);
                     //新增
                     if (substring.equals("in")) {
                        //运行sql语句
                        MysqlCenlint.inster(sqls);
                     }
                     //修改
                     else if (substring.equals("up")) {
                        MysqlCenlint.update(sqls);
                     }
                     //删除
                     else {
                        MysqlCenlint.delete(sqls);
                     }
                  }
                  //删除本地文件
                  //MysqlCenlint.deletes(fileName);
                  MysqlCenlint.deletess(fileName);
                  FtpUtil.deleteFile(ftpHost_dev, ftpPort, ftpUserName, ftpPassword, ftpPath, fileName);
                  is.close();
                  ftp.completePendingCommand();
               }
            }
            //删除本地文件
            MysqlCenlint.deletes(fileName);
            FtpUtil.deleteFile(ftpHost, ftpPort, ftpUserName, ftpPassword, "anbao/", fileName);
            //is.close();
            ftp.completePendingCommand();
            return true;
         }
@@ -156,7 +151,7 @@
      } catch (Exception e) {
         System.out.println("ftp连接失败");
         e.printStackTrace();
      } finally {