将jar内的文件复制到jar包外的同级目录下

import java.io.ByteArrayInputStream;
import java.io.File;
import java.io.IOException;
import java.io.InputStream;
import java.net.URL;
import java.nio.file.Files;
import java.nio.file.Path;
import java.nio.file.Paths;

import org.apache.commons.io.IOUtils;
import org.springframework.core.io.support.PathMatchingResourcePatternResolver;

/**
 * 将jar内的文件复制到jar包外的同级目录下
 *
 */
public class FileCopyUtils {

    private static InputStream getResource(String location) throws IOException {
        PathMatchingResourcePatternResolver resolver = new PathMatchingResourcePatternResolver();
        InputStream in = resolver.getResource(location).getInputStream();
        byte[] byteArray = IOUtils.toByteArray(in);
        in.close();
        return new ByteArrayInputStream(byteArray);
    }

    /**
     * 获取项目所在文件夹的绝对路径
     * @return
     */
    private static String getCurrentDirPath() {
        URL url = FileCopyUtils.class.getProtectionDomain().getCodeSource().getLocation();
        String path = url.getPath();
        if(path.startsWith("file:")) {
            path = path.replace("file:", "");
        }
        if(path.contains(".jar!/")) {
            path = path.substring(0, path.indexOf(".jar!/")+4);
        }

        File file = new File(path);
        path = file.getParentFile().getAbsolutePath(); 
        return path;
    }

    private static Path getDistFile(String path) throws IOException {
        String currentRealPath = getCurrentDirPath();
        Path dist = Paths.get(currentRealPath + File.separator + path);
        Path parent = dist.getParent();
        if(parent != null) {
            Files.createDirectories(parent);
        }
        Files.deleteIfExists(dist);
        return dist;
    }

    /**
     * 复制classpath下的文件到jar包的同级目录下
     * @param location 相对路径文件,例如kafka/kafka_client_jaas.conf
     * @return
     * @throws IOException
     */
    public static String copy(String location) throws IOException {
        InputStream in = getResource("classpath:"+location);
        Path dist = getDistFile(location);
        Files.copy(in, dist);
        in.close();
        return dist.toAbsolutePath().toString();
    }

}
要在Spring Boot项目中实现负载均衡,并将上传的文件保存在服务器目录中,需要遵循以下几个步骤: 1.创建Spring Boot项目:首先,需要创建一个Spring Boot项目。可以选择使用IDE工具创建一个基本模板,并在pom.xml文件中添加必要的依赖库(例如Spring Web和Spring Boot DevTools)。 2.实现文件上传功能:在Spring Boot项目中实现文件上传功能,可以使用Spring的MultipartFile类,它使得上传文件变得简单。要将上传的文件保存在服务器目录中,需要一些常规的Java文件IO操作。在控制器中,可以通过使用@requestMapping注释处理文件上传请求,并用@Value注释注入目标目录。 3.设置负载均衡:使用Spring Cloud集成负载均衡器,可以轻松地将请求转发给多个服务,从而可提高系统的可用性。使用Spring Cloud负载均衡器,需要从pom.xml文件中添加相应的依赖。在Spring Boot项目中使用负载均衡器时,需要使用Spring Cloud的@LoadBalanced注释实现“客户端负载均衡”。 4.保存文件目录:将上传的文件保存到目录jar同级,可以使用Java中的路径工具类,例如Path和Files类实现。也可以使用Spring Boot提供的特殊类PathUtils,将文件路径设置为“classpath:/static”即可。 综上,可以采取以上步骤,并使用Spring Cloud集成负载均衡器应对大量请求,实现将上传的文件保存在服务器目录jar同级
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值