公司的前端js,css是发布到oss的,所以要求后台在发布的同时先把即将要覆盖的文件备份到服务器上

步骤是先上传文件到服务器,服务器上传到oss服务器之前先备份相同文件名的文件

public class OssVersionPublishController {

@Value("${oss.endpoint}")
        public String endpoint;

@Value("${oss.accessKeyId}")
       public String accessKeyId;

@Value("${oss.secretAccessKey}")
        public String secretAccessKey;

@Value("${oss.bucketName}")
        public String bucketName;

@Value("${oss.url}")
       public String url;

public OSSClient getOSSClient(){
          return new OSSClient(endpoint, accessKeyId, secretAccessKey);
       }

/**
        * 上传文件到oss
       * */
       private boolean publishFile(List<OssVersionPublishContent> contentList,String updName){
        OSSClient ossClient = getOSSClient();
        try {
               // 文件的父父目录
                String folder =contentList.get(0).getPublishBatch();
              // 查找上传的文件是否存在oss?先备份后覆盖,先在本地服务器上创建文件夹(批次命名),先把上一次的删掉了
                String deposeFilesDir="/home/admin/ossBackUp/"+folder;
                File dest = new File(deposeFilesDir);
                if(dest.exists()){
                    delFile(dest);
                 }
               dest.mkdirs();//本地服务器创建好目录
               for(OssVersionPublishContent content:contentList){
              // 文件的父目录,判断输入的文件是否有父目录
              boolean isExistSup= content.getFileName().contains("/");
              boolean read = true;
              boolean isDoesObjectExist=true;
             try {
                  isDoesObjectExist=ossClient.doesObjectExist(bucketName,content.getFileName());
              } catch (Exception e) {
                    isDoesObjectExist = false;
               logger.warn("isDoesObjectExist异常:{}",e.getMessage());
              }
             if(isDoesObjectExist){//oss存在相同文件
                 //文件备份
                    String filePath = (deposeFilesDir +"/"+ content.getFileName()).replace("\\","/");
                    File targetFile= new File(filePath);
                   if(isExistSup){
                          if (!targetFile.getParentFile().exists()) {
                               targetFile.getParentFile().mkdirs();
                              }
                   }
                  OSSObject ossObject = ossClient.getObject(bucketName,content.getFileName());
                  FileOutputStream fos = null;
                  InputStream stream = null;
                  try {
                         fos = new FileOutputStream(targetFile);
                         stream = ossObject.getObjectContent();
                         byte[] buffer = new byte[1024*1024];
                        int byteRead = 0;
                        while((byteRead=stream.read(buffer))!=-1){
                                    fos.write(buffer, 0, byteRead);
                                    fos.flush();
                                   }
                  } catch (Exception e) {
                 read = false;
                  logger.warn("oss文件备份到本地服务器失败{}",e.getMessage());
                  return false;
                  }finally{
                   try {
                           if(fos!=null){
                                 fos.close();
                             }
                           if(stream!=null){
                                stream.close();
                            }
                   } catch (Exception e) {}
                 }
           }
              PutObjectResult result = ossClient.putObject(bucketName, content.getFileName(), new File(content.getFileUrl()));
                 logger.info("上传结果:{}",result.getETag());

if(read){
                  content.setOperateTime(new Date());
                  content.setOperator(updName);
                  content.setPublishStatus(true);
                  content.setPublishTime(new Date());
                  content.setFileStatus(true);
                  ossVersionPublishContentBiz.updateByPrimaryKey(content);
              }

};
     } catch (Exception e) {
        logger.warn("发布失败={}",e.getMessage());
         return false;
       }finally{
               ossClient.shutdown();
        }
           return true;
          }

  /**
  * 还原
  * */
  @PostMapping(value = "/restore/{id}")
  @ResponseBody
  public ObjectRestResponse<OssVersionPublish> restore(@PathVariable Long id,HttpServletRequest request) {
    String token = StringUtils.trimToEmpty(request.getHeader(userAuthConfig.getJwtTokenHeader()));//得到用户token
    try {
      OssVersionPublish ossVersionPublish = ossVersionPublishBiz.selectByPrimaryKey(id);
      if(StringUtil.isBlank(ossVersionPublish.getPublishBatch())){
      return new ObjectRestResponse<OssVersionPublish>(1, "获取参数异常");
    }
    // 修改发布版本批次的状态为未发布
    String updName = userAuthUtil.getInfoFromToken(token).getUniqueName();
    // 找到指定的目录下的所有文件,然后覆盖到oss相应的地方
    String deposeFilesDir="/home/admin/ossBackUp/"+ossVersionPublish.getPublishBatch();
    File dest = new File(deposeFilesDir);
    if(!dest.exists()){
      return new ObjectRestResponse<OssVersionPublish>(1, "备份文件丢失");
    }
    boolean flag = restoreToOss(dest,ossVersionPublish.getPublishBatch());
    if(flag){
      ossVersionPublish.setOperator(updName);
      ossVersionPublish.setOperateTime(new Date());
      ossVersionPublish.setPublishStatus(false);
      int resCount = ossVersionPublishBiz.updateByPrimaryKey(ossVersionPublish);
      if(resCount>0){
      return new ObjectRestResponse<OssVersionPublish>(0, "还原成功");
      }
    }
    } catch (Exception e) {
      logger.warn("oss发布失败{}",e.getMessage());
      return new ObjectRestResponse<OssVersionPublish>(1, "还原失败");
    }
      return new ObjectRestResponse<OssVersionPublish>(1, "还原失败");

    }

  /**
  * 还原备份到oss
  * @param publishBatch
  * */
  private boolean restoreToOss(File dest, String publishBatch){
  OSSClient ossClient = getOSSClient();
  if(dest.isDirectory()) {
  File[] files = dest.listFiles();
  logger.info("dest下的文件数量=={}",files.length);
  if(files.length==0){
    return true;
  }
  for (File f : files) {  
  if(f.isFile()){
    logger.info("路径={},版本批次={}",f.getPath(),publishBatch);
    String gt = f.getPath().substring(f.getPath().indexOf(publishBatch)+publishBatch.length()+1);
    logger.info("文件路径:{}",gt);
    // 上传文件
    PutObjectResult result = ossClient.putObject(bucketName,gt, f);
    logger.info("上传结果:{}",result.getETag());
  }else{
    logger.info("目录继续找文件=={0},{1}",f,publishBatch);
    restoreToOss(f,publishBatch);
  }
  }
  }
  return true;
  }

}

服务器上传文件到oss,以及备份的更多相关文章

  1. xshell终端向远程服务器上传文件方法

    centos-7下在本地终端里向远程服务器上传文件,在命令行中执行的软件. 安装命令如下: 在终端里输入如下命令: 会弹出如下窗口 选择你要上传的文件即可上传成功.

  2. 关于nutz跨服务器上传文件

    关于nutz跨服务器上传文件  发布于 578天前  作者 yong9664  770 次浏览  复制  上一个帖子  下一个帖子  标签: 无 是这样的,项目在一台服务器,文件要存储到另外一台服务器 ...

  3. Java模拟客户端向服务器上传文件

    先来了解一下客户端与服务器Tcp通信的基本步骤: 服务器端先启动,然后启动客户端向服务器端发送数据. 服务器端收到客户端发送的数据,服务器端会响应应客户端,向客户端发送响应结果. 客户端读取服务器发送 ...

  4. idea 内置tomcat jersey 跨服务器 上传文件报400错误

    报错内容 com.sun.jersey.api.client.UniformInterfaceException: PUT http://.jpg returned a response status ...

  5. 【FTP】C# System.Net.FtpClient库连接ftp服务器(上传文件)

    如果自己单枪匹马写一个连接ftp服务器代码那是相当恐怖的(socket通信),有一个评价较高的dll库可以供我们使用. 那就是System.Net.FtpClient,链接地址:https://net ...

  6. ASP.NET跨服务器上传文件的相关解决方案

    第一种:通过FTP来上传文件 首先,在另外一台服务器上设置好FTP服务,并创建好允许上传的用户和密码,然后,在ASP.NET里就可以直接将文件上传到这台 FTP 服务器上了.代码如下: <%@ ...

  7. Javaweb向服务器上传文件以及从服务器下载文件的方法

    先导入jar包 点击下载 commons-fileupload是Apache开发的一款专门用来处理上传的工具,它的作用就是可以从request对象中解析出,用户发送的请求参数和上传文件的流. comm ...

  8. 使用Putty实现windows向阿里云的Linux云服务器上传文件

    1.首先获取PSCP工具 PuTTY小巧方便.但若需要向网络中的Linux系统上传文件,则可以使用PuTTY官方提供的PSCP工具来实现上传.PSCP是基于ssh协议实现. 可以点击这里下载 2.启动 ...

  9. asp.net 服务器 上传文件到 FTP服务器

    private string ftpServerIP = "服务器ip";//服务器ip private string ftpUserID = "ftp的用户名" ...

随机推荐

  1. 代码审计-thinkphp3.2.3框架漏洞sql注入

    开始复现审计一下tp3和tp5的框架漏洞,当个练习吧. 涉及注入的方法为where() table() delete()等. 环境 tp3.2.3 : 0x01 注入成因 测试代码: public f ...

  2. Neo4j:图数据库GraphDB(一)入门和基本查询语句

    图数据库的代表:Neo4j 官网:  http://neo4j.com/ 引言:为什么使用图数据库 在很多新型项目中,应用图数据库已经是势在必行的趋势了,因为图数据库可以很好的表示各种节点与关系的概念 ...

  3. ‎Cocos2d-x 学习笔记(3.1) Scene 场景与场景切换

    1. Scene 简介 游戏中我们看到/看不到的所有元素都是展示在场景之Scene上. 我们可以把场景比作放在地上的没盖纸箱,层Layer是纸箱里堆放的玻璃,Sprite等元素画在玻璃Layer上,这 ...

  4. 日志::spdlog

    https://github.com/gabime/spdlog git clone https://github.com/gabime/spdlog.git cd spdlog && ...

  5. .NetCore——中小企业架构及通用权限管理系统开篇

    博客开通已经7年多了,也没写过什么东西,最近,突然想记录下自己的软件开发生涯,于是,找回账户,登录一看,还是当时还是在学校的时候学习的时候记录过一个sql批量到数据的Demo,近两年来,微服务架构火起 ...

  6. 【RabbitMQ 实战指南】一 死信队列

    1.死信队列 DLX,全称为 Dead-Letter-Exchange,可以称之为死信交换器.当消息在一个队列中变成死信(dead message)之后,它能被发送到另一个交换器中,这个交换器就是DL ...

  7. 关于Linux中的 localhost 默认地址简单介绍

    大家都知道localhost指的是本机的IP地址:127.0.0.1 用于回路测试,那能不能修改localhost呢,答案肯定是可以的 打开终端--->输入: vim /etc/host  然后 ...

  8. ThingJS和传统3D开发的区别

    物联网3D可视化开发已经辐射到各行各业,无论车间还是消防,城市还是粮仓,亦或是地铁.科技园,物联网可视化是科技的进步,也是行业的进步.而传统的3D可视化开发实施起来并不那么乐观.如果使用ThingJS ...

  9. 阿里巴巴开源故障注入工具_chaosblade

    chaosblade是阿里巴巴最近开源的一款故障注入的工具,因为我最近在做公司的虚拟化平台的可靠性测试工具,无意中发现这个工具,个人感觉比较有用,用起来也比较简单,所以拿出来分享一下,期望对大家的工作 ...

  10. 在元素上写事件和addEventListent()的区别

    在元素上写事件和addEventListent()的区别1. onclick添加事件不能绑定多个事件,后面绑定的会覆盖前面的.而addEventListener能添加多个事件绑定,按顺序执行.2. a ...