GitLab API学习总结

最新更新时间:2021年07月27日16:05:07
《猛戳-查看我的博客地图-总有你意想不到的惊喜》

文章背景:最近在开发一个需求,在一个PC端中台系统上(前端是antD搭建的React项目+后端是eggJS搭建的Node项目),前端交互点击一个按钮,需要在Node服务器上完成一系列动作:在GitLab上创建一个新仓库 -> 在Node服务器上动态初始化一个react项目 -> 改写这个项目中的一写文件内容 -> 将这个react项目push到新仓库

本文内容:在进行代码管理时,通常用到的是gitlab,但大多数人用的都是界面化操作,比如:创建仓库、查询仓库、修改仓库信息,实际上gitlab也可以通过发送接口请求的方式进行操作,本文主要介绍如何调用gitlab的API接口、不同接口的含义

预备知识

接口路径
  • gitlab API主域名和接口前置路径
//主域名
let host = "https://gitlab.***.com";// ***-公司的gitlab的主域名
//接口前置路径
let mainPath = "/api/v3";

注意:v3有可能是v2、v4…,每个公司的不一样

API地址列表
  • 从帮助(http://gitlab.***.com/help)进入
    在这里插入图片描述
  • 直接从地址(http://gitlab.***.com/help/api/README.md)进入
    在这里插入图片描述
private_token
介绍
  • Gitlab的所有API都需要提供private_token参数进行用户身份认,如果没有提供或者提供的private_token不合法,API将会返回401错误码
  • private_token是用来代表用户身份的字符串,和用户是一一对应的关系,http请求中包含这个就可以免输入用户名和密码。
获取
  • 方案一:查看帐号设置(Profile Settings -> Account)
    在这里插入图片描述
  • 方案二:通过API

接口路径: /session

postman的方式如下

在这里插入图片描述

服务发请求的方式如下

const child_process = require("child_process");
let curl = `curl --request POST --data "login=wanshaobo&email=***&password=***" ${host}${mainPath}/session`;
let buffer = child_process.execSync(curl);//发送同步请求
let resultJson = buffer && buffer.toString();
let result = JSON.parse(resultJson);
//result结果
console.log(result.private_token)
{
    "name": "万少博",
    "username": "wanshaobo",
    "id": 1,
    "state": "active",
    "avatar_url": "https://work.***.com/photo/1.jpg",
    "web_url": "http://gitlab.***.com/u/wanshaobo",
    "email": "wanshaobo@***.com",
    "private_token": "***"
}

注意:
git config --global user.name #获取用户名
git config --global user.email #获取用户邮箱

http请求方式
  • gitlab api限制了请求的方法,一般查询请求是GET,创建请求是POST,修改请求是PUT,删除请求是DELETE,方法写错了api将返回405 Method Not Allowed错误。
  • 分页查询需要携带参数per_page和page
`curl --request GET --data "private_token=***&per_page=10&page=1" ${host}${mainPath}/projects/owned`;

项目中用到的API

获取自己名下的所有项目
  • /projects/owned
let curl = `curl --request GET --data "private_token=***" ${host}${mainPath}/projects/owned`;
获取命名空间
  • /namespaces
let curl = `curl --request GET --data "private_token=***" ${host}${mainPath}/namespaces`;
创建仓库
  • /projects
let curl = `curl --request POST --data "visibility_level=0&private_token=***&namespace_id=***" ${host}${mainPath}/projects?name=new_demo`;

注意:参数visibility_level是仓库的访问权限,可以设置0,10,20

在这里插入图片描述

API大全

  • Users 用户
接口类型返回值
/usersGET用户列表
/users/:idGET用户详情
/usersPOST创建用户
  • Session 会话
接口类型返回值
/sessionPOST用户帐号详情
  • Projects including setting Webhooks
  • Project Snippets
  • Services
  • Repositories 项目仓库
  • Repository Files 仓库代码文件
  • Commits 提交
  • Tags
  • Branches 分支
  • Merge Requests 代码合并
  • Issues
  • Labels
  • Milestones
  • Notes (comments) 注释
  • Deploy Keys
  • System Hooks
  • Groups 群组
接口类型返回值
/groupsGETGet a list of groups
/groups/:id/projectsGETGet a list of projects in this group
  • Namespaces 命名空间
接口类型返回值
/namespacesGETGet a list of namespaces
/namespaces?search=foobarGETGet all namespaces that match your string in their name or path
  • Settings
  • Keys
参考资料

感谢阅读,欢迎评论^-^

打赏我吧^-^

  • 4
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 要使用Java调用GitLab API,您需要使用Java GitLab API客户端库。这些库提供了一组Java类和方法,可用于与GitLab API进行交互。 以下是使用Java GitLab API客户端库调用GitLab API的一些步骤: 1. 首先,您需要在GitLab上创建一个API令牌。这将允许您使用API进行身份验证和访问。 2. 接下来,您需要在Java项目中添加Java GitLab API客户端库的依赖项。您可以使用Maven或Gradle等构建工具来添加依赖项。 3. 然后,您需要创建一个GitLab API客户端实例,并使用您的API令牌进行身份验证。 4. 接下来,您可以使用客户端实例调用GitLab API的各种端点。例如,您可以使用客户端实例获取GitLab项目的列表,创建新项目,更新项目等。 5. 最后,您需要处理API响应并执行适当的操作。例如,您可以将响应转换为Java对象,将其写入文件或将其显示在控制台上。 希望这些步骤能帮助您开始使用Java GitLab API客户端库调用GitLab API。 ### 回答2: GitLab 是一款强大的开源代码管理工具,而 GitLab API 则是一套使用 RESTful 风格的 Web API,可以方便地从外部应用程序调用 GitLab 中的功能和数据。Java 作为一门通用性强的编程语言,自然也具备着使用 GitLab API 的能力。 在使用 GitLab API 调用 GitLab 功能或获取数据之前,首先需要了解一些常用的 API 操作。GitLab API 包含了许多不同的端点,例如用户、组、项目、分支、提交等等,我们需要先确定需要使用哪些 API 来完成我们的操作。另外,为了安全起见,每次 API 请求都需要一个有效的访问令牌或私人令牌,以保护数据的安全性。 在 Java 中使用 GitLab API 首先需要导入相应的 API 库,例如 GitLab4J,GitLab API Java Client 等。这些库包含了相关的类和方法,我们可以使用这些类和方法来进行 GitLab API 的调用。具体步骤如下: 1. 创建 GitLab API 的客户端对象,可以根据被调用的 GitLab 实例地址、API 访问令牌等信息进行初始化。 2. 根据需要设置 API 请求参数,例如项目 ID、用户 ID、仓库名称、分支名称等等。 3. 调用相应的 API 接口,例如获取某个项目的所有分支信息、获取某个用户信息等等。 4. 处理 API 返回结果,例如将分支信息存储在本地数据库中、将用户信息展示在前端页面上等等。 需要注意的是,在使用 GitLab API 进行操作的时候,要避免频繁访问 GitLab 服务器,以免给服务器带来过大的负担。可以通过缓存、批量查询、限流等方式来降低 API 请求频率,保证系统的稳定性和可靠性。 总之,使用 Java 调用 GitLab API 可以帮助我们更方便地管理和维护代码项目,提高开发效率和质量。只要掌握了一些基本的 API 调用技巧,就能够快速地编写出高效、安全的 GitLab API 调用代码。 ### 回答3: 一、Gitlab API Gitlab APIGitlab 提供的一套 RESTful 风格的 API 接口,可以通过 API 接口来访问 Gitlab 提供的各种功能,例如:创建用户、添加项目、查询代码、创建 Merge Request 等等。 Gitlab API 是基于 HTTP/HTTPS 协议,采用 JSON 格式返回,支持各种编程语言访问,例如:Java、Python、PHP 等等。 二、Java 调用 Gitlab API Java 调用 Gitlab API 的方式主要有两种,一种是使用 Gitlab 提供的 Java 客户端库进行访问,另一种是使用 Apache HttpClient 进行访问。 1. 使用 Gitlab Java 客户端库进行访问 Gitlab 提供了 Java 客户端库 GitLab4J,该库封装了 Gitlab API 的所有功能,便于在 Java 项目中进行集成和调用。 GitLab4J 的使用流程如下: (1)在项目的 pom.xml 文件中添加依赖: ``` <dependency> <groupId>org.gitlab4j</groupId> <artifactId>gitlab4j-api</artifactId> <version>4.18.0</version> </dependency> ``` (2)创建 GitlabApiClient 对象: ``` GitlabApiClient gitlabApiClient = GitlabApiClient.newBuilder("http://gitlab.com/api/v4") .withOAuth2Token("1a2b3c4d") // accessToken or personalToken .build(); ``` (3)调用 Gitlab API 接口: ``` List<GitlabProject> projects = gitlabApiClient.getProjects(); ``` 2. 使用 Apache HttpClient 进行访问 Apache HttpClient 是一个开源的 HTTP 组件,可以在 Java 中使用该组件进行 HTTP 请求。 Apache HttpClient 的使用流程如下: (1)导入 HttpClient 和 HttpClient 常用的依赖库: ``` <dependency> <groupId>org.apache.httpcomponents</groupId> <artifactId>httpclient</artifactId> <version>4.5.13</version> </dependency> <dependency> <groupId>org.apache.httpcomponents</groupId> <artifactId>httpmime</artifactId> <version>4.5.13</version> </dependency> ``` (2)创建 HttpClient 对象: ``` CloseableHttpClient httpClient = HttpClients.createDefault(); ``` (3)创建 HttpGet 或 HttpPost 请求对象: ``` HttpGet httpGet = new HttpGet("http://gitlab.com/api/v4/projects"); httpPost = new HttpPost("http://gitlab.com/api/v4/projects"); ``` (4)调用 Gitlab API 接口: ``` CloseableHttpResponse httpResponse = httpClient.execute(httpGet); HttpEntity entity = httpResponse.getEntity(); String response = EntityUtils.toString(entity, "utf-8"); ``` 三、注意事项 (1)GitLab API 对每个用户有请求限制,一般情况下是每个用户最多请求 6 次/分钟,超出限制会返回 429 Too Many Requests 错误。 (2)Java 客户端库 GitLab4J 对 Gitlab API 进行了封装,使用起来更加简单,但是需要注意版本兼容性。 (3)使用 Apache HttpClient 进行访问时需要注意解析 Json 返回值的方式,一般情况下需要使用 json-lib、gson 等库进行解析。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值