使用接口实现将本地jar包传到nexus仓库中

简介: 使用接口实现将本地jar包传到nexus仓库中

背景

目前我们要把项目的包推送到nexu仓库中需要在项目的父pom中写部分代码,如下,但是往下边拉jar包的时候删除pom文件中的配置也能实现

,说明下拉的时候是走的setting文件中的配置。那我们思考,根据面向对象编码中的最小知道原则:具体项目原则上不需要知道nexus的相关配置,我们是不是可以将这一层耦合解开呢

目前使用方式:

setting文件配置

<?xml version="1.0" encoding="UTF-8"?>
<settings xsi:schemaLocation="http://maven.apache.org/SETTINGS/1.0.0 http://maven.apache.org/xsd/settings-1.0.0.xsd" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://maven.apache.org/SETTINGS/1.0.0">
<!-- 本地仓库地址 -->
<localRepository>yourRepositoryPosition</localRepository>
<!--nexus服务器,id自定义,用户名和密码为nexus服务器的账号密码-->
  <servers>  
  <!--id为对应资源库id-->  
    <server>  
        <id>test_snapshot_hosted</id>  
        <username>admin</username>  
        <password>admin</password>  
    </server>
    <server>  
        <id>test_hosted</id>  
        <username>admin</username>  
        <password>admin</password>  
    </server>  
    <server>  
        <id>nexus</id>  
        <username>admin</username>  
        <password>admin</password>  
    </server>   
  </servers>  
  <!--组资源库的url地址  id和name自定义,mirrorOf的值设置为central,写死的-->  
  <mirrors>     
    <mirror>  
        <id>nexus</id>  
        <name>nexus repository</name>  
        <url>http://192.168.XXXXX.220:8089/repository/test_group/</url>  
        <mirrorOf>central</mirrorOf>  
    </mirror>     
  </mirrors>  
</settings>

项目父pom中配置

<distributionManagement>
        <!--Release类型的托管资源库-->
        <repository>
            <!--id对应nexus仓库的id-->
            <id>test_hosted</id>
            <!--自定义名称-->
            <name>Releases</name>
            <!--仓库对应的URL地址-->
            <url>http://192.168.60.xxxx:8089/repository/test_hosted/</url>
        </repository>
        <!--Snapshot类型的托管资源库-->
        <snapshotRepository>
            <!--id对应nexus仓库的id-->
            <id>test_snapshot_hosted</id>
            <!--自定义名称-->
            <name>Snapshot</name>
            <!--仓库对应的URL地址-->
            <url>http://192.168.60.xxxx:8089/repository/test_snapshot_hosted/</url>
        </snapshotRepository>
    </distributionManagement>

优化方案

1、使用接口调用

通过写代码的方式将本地打好的jar包通过调接口的方式上传到仓库中。

引入依赖

<dependency>
                <groupId>org.apache.httpcomponents</groupId>
                <artifactId>httpcore</artifactId>
            </dependency>
            <dependency>
                <groupId>org.springframework</groupId>
                <artifactId>spring-web</artifactId>
            </dependency>

实际编码

public static void main(String[] args)  {
            RestTemplate restTemplate = new RestTemplate();
            String username = "admin";
            String password = "admin";
            restTemplate.getInterceptors().add(
                    new BasicAuthenticationInterceptor(username, password));
            String filename = "D:\\项目开发\\metaverse3-backend\\metaverse3-gateway\\target\\metaverse3-gateway-1.0-SNAPSHOT.jar";
            File file = new File(filename);
            FileSystemResource resource = new FileSystemResource(file);
            MultiValueMap<String, Object> requestMap = new LinkedMultiValueMap<>();
            requestMap.add("file", resource);
            HttpHeaders headers = new HttpHeaders();
            headers.setContentType(MediaType.MULTIPART_FORM_DATA);
            HttpEntity<MultiValueMap<String, Object>> requestEntity = new HttpEntity<>(requestMap, headers);
            test(restTemplate,requestEntity);
        }
        public static void test(RestTemplate restTemplate ,HttpEntity<MultiValueMap<String, Object>> requestEntity){
            String url = "http://192.168.xx.xxx:xxxx/repository/test_snapshot_hosted/";
            String groupId = "com.yourcompany";
            String artifactId = "my-artifact";
            String version = "1.0-SNAPSHOT";
            String packaging = "jar";
            String classifier = "my-classifier";
            String repositoryPath = groupId.replace('.', '/') + '/' + artifactId + '/' + version + '/' + artifactId + '-' + version + (classifier == null ? "" : '-' + classifier) + '.' + packaging;
            String nexusUrl = url + repositoryPath;
            ResponseEntity<String> responseEntity = restTemplate.exchange(nexusUrl, HttpMethod.PUT, requestEntity, String.class);
        }

结果

2、使用mvn命令手动推(需要在setting文件中配置密码,详情见文章最上边setting文件)

mvn deploy:deploy-file -DgroupId=com.tfjybj -DartifactId=metaverse-gateway -Dversion=1.0.0-SNAPSHOT -Dpackaging=jar -Dfile=E:\zy\TGB-zgy-2023\待删除\metaverseDemo\metaverse-gateway\target\metaverse-gateway-1.0-SNAPSHOT.jar -Durl=http://192.168.XXX.220:8089/repository/test_snapshot_hosted/ -DrepositoryId=test_snapshot_hosted

总结

1、设计模式中的七大原则也可以用到生活中,最小知道原则可以保证安全性,我们要做的更多的是要知道原则为什么产生而不是怎么使用。

2、能交给机器做的不要交给人去做。

maven概念参考

nexus概念参考


相关文章
|
Java
[JarEditor]可直接修改jar包的IDEA插件
### 修改JAR包变得更简单:JarEditor插件简介 **背景:** 开发中常需修改JAR包中的class文件,传统方法耗时费力。JarEditor插件让你一键编辑JAR包内文件,无需解压。 **插件使用:** 1. **安装:** 在IDEA插件市场搜索JarEditor并安装。 2. **修改class:** 打开JAR文件中的class,直接编辑,保存后一键构建更新JAR。 3. **文件管理:** 右键菜单支持在JAR内新增/删除/重命名文件等操作。 4. **搜索:** 使用内置搜索功能快速定位JAR包内的字符串。
1359 2
[JarEditor]可直接修改jar包的IDEA插件
|
弹性计算 Java Serverless
Serverless 应用引擎操作报错合集之上传自定义JAR包,启动时报错,是什么导致的
Serverless 应用引擎(SAE)是阿里云提供的Serverless PaaS平台,支持Spring Cloud、Dubbo、HSF等主流微服务框架,简化应用的部署、运维和弹性伸缩。在使用SAE过程中,可能会遇到各种操作报错。以下是一些常见的报错情况及其可能的原因和解决方法。
|
关系型数据库 Java 分布式数据库
PolarDB产品使用问题之部署到服务器上的Java应用(以jar包形式运行)无法连接,如何解决
PolarDB产品使用合集涵盖了从创建与管理、数据管理、性能优化与诊断、安全与合规到生态与集成、运维与支持等全方位的功能和服务,旨在帮助企业轻松构建高可用、高性能且易于管理的数据库环境,满足不同业务场景的需求。用户可以通过阿里云控制台、API、SDK等方式便捷地使用这些功能,实现数据库的高效运维与持续优化。
|
监控 Ubuntu Java
如何在Ubuntu上运行Jar包?
【7月更文挑战第9天】
824 0
如何在Ubuntu上运行Jar包?
|
Java Maven
SpringBoot 引用仓库中没有 第三方包 - 将jar 包安装本地 maven
SpringBoot 引用仓库中没有 第三方包 - 将jar 包安装本地 maven
182 0
|
Java 应用服务中间件
tomcat7 与 tomcat8 加载 jar包的顺序
tomcat7 与 tomcat8 加载 jar包的顺序
442 0
|
Java 应用服务中间件 API
java 启动查看jar包加载顺序并设置classpath
java 启动查看jar包加载顺序并设置classpath
961 0
|
敏捷开发 Java Devops
阿里云云效产品使用合集之将代理仓库关闭,之前通过代理同步的jar包会继续存在于企业仓库中吗
云效作为一款全面覆盖研发全生命周期管理的云端效能平台,致力于帮助企业实现高效协同、敏捷研发和持续交付。本合集收集整理了用户在使用云效过程中遇到的常见问题,问题涉及项目创建与管理、需求规划与迭代、代码托管与版本控制、自动化测试、持续集成与发布等方面。
|
缓存 Java Maven
IntelliJ IDEA中无法加载jar包导致出现“cannot resolve symbol...”问题的解决
IntelliJ IDEA中无法加载jar包导致出现“cannot resolve symbol...”问题的解决
661 0

热门文章

最新文章