当前位置:首页 > 技术分析 > 正文内容

java调用API操作GitLab

ruisui884个月前 (01-08)技术分析24

最近需要在一个WEB项目中集成GitLab,用到了GitLab的API操作,在网上找了很久都是说直接调用GitLab的Http接口,而且API官方只有javadoc没有其它说明文档,特别记录下,以备查询。这里采用Token的认证方式,因此需要先登陆GitLab新建一个Token,创建方式如下:


创建完成以后,就可以在API中通过Token进行登陆并操作该GitLab服务了,以下是源码

package org.noka.gitlab.gitlab.service;

import org.apache.commons.codec.binary.Base64;
import org.gitlab.api.GitlabAPI;
import org.gitlab.api.models.GitlabBranch;
import org.gitlab.api.models.GitlabProject;
import org.gitlab.api.models.GitlabRepositoryFile;
import org.gitlab.api.models.GitlabSimpleRepositoryFile;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.stereotype.Service;
import org.springframework.web.multipart.MultipartFile;

import java.util.List;

/** ------------------------------------------------------------
 * GitLab 操作服务
 * 包含分支创建,获取分支列表,上传文件,下载文件
 * 依赖于java-gitlab-api 4.1.1
 * @author  xiefangjian@163.com
 * @version 1.0.0
 ** ---------------------------------------------------------**/
@Service
public class GitLabService {

    private static Logger logger = LoggerFactory.getLogger(GitLabService.class);

    @Value("${gitlab.token}")
    private String token;           //GitLab Token,这里用gitlab的token连接,也可以用用户名和密码连接
    @Value("${gitlab.url}")
    private String url;             //GitLab 服务器地址
    @Value("${gitlab.projectid}")
    private String projectid;       //项目ID

    /**
     * 创建分支
     * @param name 新分支的名称
     * @param ref  分支来源
     * @return 分支创建成功返回true,创建失败返回false
     */
    public boolean createBaranche(String name,String ref){
        try {
            GitlabAPI api = GitlabAPI.connect(url, token);//连接服务器
            api.setConnectionTimeout(200);//设置连接超时
            GitlabProject gp = api.getProject(projectid);//根据项目ID切换到指定项目的仓库
            //以上部分代码也可以在spring中通过注解引入
            api.createBranch(gp,name,ref);//在指定项目下创建分支
            return true;//创建成功
        }catch (Exception ex){
            logger.error(ex.getMessage());
        }
        return false;//创建失败
    }

    /**
     * 获取分支列表
     * @return 成功时返回分支列表,失败返回null
     */
    public List<GitlabBranch> getListBranches(){
        try {
            GitlabAPI api = GitlabAPI.connect(url, token);//连接服务器
            api.setConnectionTimeout(200);//设置连接超时
            GitlabProject gp = api.getProject(projectid);//根据项目ID切换到指定项目的仓库
            return api.getBranches(gp);//获取所有分支
        }catch (Exception ex){
            logger.error(ex.getMessage());
        }
        return null;//获取失败时返回null
    }

    /**
     * 下载文件
     * @param path 文件路径
     * @param ref  文件所在分支
     * @return 成功返回文件内容,失败返回null
     */
    public byte[] getFile(String path,String ref){
        try {
            GitlabAPI api = GitlabAPI.connect(url, token);//连接服务器
            api.setConnectionTimeout(200);//设置连接超时
            GitlabProject gp = api.getProject(projectid);//根据项目ID切换到指定项目的仓库
            GitlabRepositoryFile gfile = api.getRepositoryFile(gp,path,ref);//根据项目,路径,分支获取具体的文件内容
            Base64 bs = new Base64();//Base64转换工具类,依赖于commons-codec 1.14
            return bs.decode(gfile.getContent());//从GitLab上获取的文件是以Base64字符串形式返回的,需要转成byte[]
        }catch (Exception ex){
            logger.error(ex.getMessage());
        }
        return null;//失败返回null
    }

    /**
     * 上传文件
     * @param branch 需要上传到具体哪个分支
     * @param path   文件在GitLab上的路径,可以有多级目录如/doc/man/等,如果目录不存在会自动创建
     * @param msg    文件上传备注
     * @param file   文件对象
     * @return 成功返回true 失败返回false
     */
   public boolean upfile(String branch,String path,String msg,MultipartFile file){
       try {
           GitlabAPI api = GitlabAPI.connect(url, token);//连接服务器
           api.setConnectionTimeout(200);//设置连接超时
           GitlabProject gp = api.getProject(projectid);//根据项目ID切换到指定项目的仓库
           Base64 bs = new Base64();//Base64转换工具类,依赖于commons-codec 1.14
           String body = bs.encodeAsString(file.getBytes());//文件内容,GitLab只接受Base64字符串的文件内容,这里需要将文件转换成Base64字符串上传
           try {
               GitlabSimpleRepositoryFile gf = api.createRepositoryFile(gp, path+"/" + file.getOriginalFilename(), branch, msg, body);//上传文件
           }catch (Exception es) {//文件存在
               logger.error(path+"/" + file.getOriginalFilename()+"  所传文件已经存在,执行更新操作");
               api.updateRepositoryFile(gp, path+"/" + file.getOriginalFilename(), branch, msg, body);//更新文件
           }
           return true;//上传成功
       }catch (Exception ex){
           logger.error(ex.getMessage());
       }
       return false;//上传失败
   }
}

扫描二维码推送至手机访问。

版权声明:本文由ruisui88发布,如需转载请注明出处。

本文链接:http://www.ruisui88.com/post/119.html

分享给朋友:

“java调用API操作GitLab” 的相关文章

2021最全VUE面试题,奥利给

1. vue-router用过没,哪些常用的钩子函数路由钩子的执行流程,钩子函数种类有:全局守卫、路由守卫、组件守卫。首页可以控制导航跳转, beforeEach , afterEach 等,?般?于页? title 的修改。?些需要登录才能调整??的重定向功能。beforeEach 主要有3个参数...

vue3使用vue-router路由(路由懒加载、路由传参)

vue-router 是 vue的一个插件库1. 专门用来实现一个SPA单页面应用2 .基于vue的项目基本都会用到此库SPA的理解1) 单页Web应用(single page web application,SPA)2) 整个应用只有一个完整的页面3) 点击页面中的链接不会刷新页面, 本身也不会向...

「干货」Vue+Element前端导入导出Excel

作者:xrkffgg转发链接:https://segmentfault.com/a/11900000189936191 前言1.1 业务场景由前台导入Excel表格,获取批量数据。根据一个数组导出Excel表格。2 实现原理2.1 引入工具库file-saver、xlsx、script-loader...

VUE 技术栈

官网链接:https://cn.vuejs.org/什么是vue:渐进式JavaScript 框架vue-cli链接:https://cli.vuejs.org/vue-cli安装:npm install -g @vue/clivue -V创建一个项目:vue create xxxxxx模版语法:文...

SpringBoot2.X+Vue+UniAPP,全栈开发医疗小程序

//xia仔のke:chaoxingit.com/208/全栈开发医疗小程序:利用Spring Boot 2.X、Vue和UniApp在当今数字化时代,医疗行业也在不断地迈向信息化和智能化的方向。开发一款医疗小程序,能够为用户提供便捷的医疗服务和信息查询,为医疗机构提供高效的管理和服务渠道。本文将介...

微信正开发“应用号”取代手机应用

长江商报消息用户只需关注公众号,不必下载APP就可获得相同体验本报讯(记者 陈妮希)昨日,2016微信公开课PRO版在广州举行,腾讯公司高级执行副总裁、微信事业群总裁张小龙首次公开演讲,并透露微信正在开发“应用号”,将应用和订阅号相结合。现场,微信团队还首次发布了腾讯生物识别标准“TENCENTSO...