Git 实战:如何将本地 .NET 项目推送到 GitLab 私有仓库

本文详细介绍如何将一个包含多个子项目的 .NET 解决方案完整推送到 GitLab 私有仓库,涵盖远程仓库配置、凭据认证、受保护分支处理等实战技巧。

一、项目背景

最近接手了一个 .NET 游戏管理后台项目(WHQJAdmin),需要将本地所有工程代码推送到公司内部的 GitLab 私有仓库。项目结构如下:

```

WHQJAdmin/

├── Services/

│ ├── Game.Data/

│ ├── Game.Entity/

│ ├── Game.Facade/

│ └── Game.IData/

├── WebProjects/

│ └── Game.Web/

└── WHQJAdmin.sln

```

远程仓库地址:`http://192.168.1.19/dev_group/game_admin_vue_net10.git\`

二、添加远程仓库

首先检查当前的 Git 状态和远程仓库配置:

```bash

git status

git remote -v

```

添加新的远程仓库(命名为 `dev`):

```bash

git remote add dev http://192.168.1.19/dev_group/game_admin_vue_net10.git

```

验证远程仓库是否添加成功:

```bash

git remote -v

```

输出应显示:

```

dev http://192.168.1.19/dev_group/game_admin_vue_net10.git (fetch)

dev http://192.168.1.19/dev_group/game_admin_vue_net10.git (push)

origin https://github.com/tonyimax/whdlm.git (fetch)

origin https://github.com/tonyimax/whdlm.git (push)

```

三、配置认证凭据

3.1 使用 Access Token 认证

GitLab 私有仓库推送需要认证。推荐使用 **Personal Access Token** 而非密码:

  1. 登录 GitLab,进入 `Settings` → `Access Tokens`

  2. 创建具有 `write_repository` 权限的 Token

  3. 将 Token 嵌入远程仓库 URL:

```bash

git remote set-url dev http://tonyimax:glpat-xxxxxxxxxxx@192.168.1.19/dev_group/game_admin_vue_net10.git

```

> ⚠️ **安全提示**:Token 相当于密码,请勿泄露或提交到代码仓库!

3.2 可选:配置 Git 凭据缓存

```bash

git config credential.helper store

```

四、提交本地代码

4.1 添加所有文件

```bash

git add -A

```

4.2 提交变更

```bash

git commit -m "Add WHQJAdmin projects"

```

提交结果示例:

```

main c77986d Add WHQJAdmin projects

20333 files changed, 2095978 insertions(+), 145114 deletions(-)

create mode 100644 Services/Game.Data/Game.Data.csproj

create mode 100644 WebProjects/Game.Web/Program.cs

...

```

五、处理受保护分支

5.1 常见问题

直接推送时可能遇到以下错误:

**错误 1:强制推送被拒绝**

```

remote: GitLab: You are not allowed to force push code to a protected branch on this project.

! remote rejected main -> main (pre-receive hook declined)

```

**错误 2:远程仓库已有内容**

```

! rejected main -> main (fetch first)

```

**错误 3:受保护分支无法推送**

```

remote: GitLab: You are not allowed to push code to protected branches on this project.

! remote rejected main -> main (pre-receive hook declined)

```

5.2 解决方案

GitLab 的 `main` 分支通常设置为**受保护分支**,防止意外推送。有两种解决方案:

方案一:先拉取再推送(需要推送权限)

```bash

git pull dev main --allow-unrelated-histories --no-edit

git push -u dev main

```

方案二:推送到新分支(推荐)

```bash

git push -u dev main:dev_branch

```

推送成功后输出:

```

分支 'main' 设置为使用变基来跟踪 'dev/dev_branch'。

To http://192.168.1.19/dev_group/game_admin_vue_net10.git

* new branch main -> dev_branch

```

六、创建合并请求(Merge Request)

推送到 `dev_branch` 分支后,在 GitLab 上创建 Merge Request:

  1. 访问 GitLab 项目页面

  2. 点击 `Merge requests` → `New merge request`

  3. 源分支选择 `dev_branch`,目标分支选择 `main`

  4. 填写合并请求说明,提交审核

或直接访问:

```

http://gitlab.example.com/dev_group/game_admin_vue_net10/-/merge_requests/new?merge_request[source_branch]=dev_branch

```

七、完整命令汇总

```bash

1. 添加远程仓库

git remote add dev http://192.168.1.19/dev_group/game_admin_vue_net10.git

2. 配置 Token 认证

git remote set-url dev http://tonyimax:glpat-xxxxxxxxxxx@192.168.1.19/dev_group/game_admin_vue_net10.git

3. 提交所有代码

git add -A

git commit -m "Add WHQJAdmin projects"

4. 推送到新分支(避开受保护分支限制)

git push -u dev main:dev_branch

```

八、常见问题排查

| 问题 | 原因 | 解决方案 |

|------|------|----------|

| `Access denied` | Token 错误或权限不足 | 检查 Token 是否有效,确认有 `write_repository` 权限 |

| `protected branch` | 分支受保护 | 推送到新分支,然后创建 Merge Request |

| `fetch first` | 远程有本地没有的提交 | 先 `git pull` 合并再推送 |

| `could not read Username` | HTTP 认证失败 | 将 Token 嵌入 URL 或配置凭据助手 |

九、总结

本文介绍了将 .NET 项目推送到 GitLab 私有仓库的完整流程,重点解决了以下问题:

  1. ✅ 多远程仓库配置

  2. ✅ Access Token 认证配置

  3. ✅ 受保护分支的正确处理方式

  4. ✅ Merge Request 创建流程

对于企业级开发,建议使用受保护分支 + Merge Request 的工作流,确保代码质量和权限管控。


**参考资料**:

> 欢迎关注我,获取更多实战技术文章!

相关推荐
追逐时光者1 天前
一个基于 .NET 与 Avalonia 构建、面向 TrinityCore 的开源 WoW 数据库编辑器
后端·.net
追逐时光者1 天前
精选 5 款基于 .NET 开源免费、功能强大的 Windows 系统优化工具
后端·.net
恋喵大鲤鱼1 天前
git mv
git·git mv
Patrick_Wilson1 天前
Git Worktree 原理详解:从 objects / refs 看懂多分支并行与多 Agent 协作
git·面试·ai编程
yaoxiaoganggang1 天前
克隆 Superpowers 的规则库到你的本地(或者直接作为 Git Submodule)
人工智能·经验分享·git·ai编程
Python私教1 天前
用 Claude Code 做大型重构不翻车:分批+Git 兜底+验证闭环的实战流程(2026)
git·重构·ai编程·代码重构·工程实践·claude code
Shawn Dev1 天前
团队协作中的 Git Tag 最佳实践:从入门到精通
大数据·git·elasticsearch
123的故事1 天前
工具分享(2)-NSmartProxy内网穿透工具。
c#·.net·nsmartproxy
独隅1 天前
Git/GitHub/GitLab/Gitee 核心对比指南
git·gitlab·github
佛山个人技术开发2 天前
GitCode个人技术开发者总结完整使用指南
windows·git·svn·github·gitcode