由于.git/config导致的Git存储库泄露

1. 背景

1.1 概述

最近在加强网站的安全性,使用了华为云的漏洞扫描服务,发现存在高风险的Git存储库泄露。这是由于对于对Gitlab的系统和目录结构不够熟悉,没有做好及时的规避。

1.2 详情

以上漏洞的现象为,访问站点下的https:xxx.domain.com/.git/config 可以下载相关文件,内容如下:

[core]
	repositoryformatversion = 0
	filemode = true
	bare = false
	logallrefupdates = true
[remote "origin"]
	url = ssh://git@xxx.domain.com/root/project_xxx.git
	fetch = +refs/heads/*:refs/remotes/origin/*

很明显,暴露出了你的代码仓库地址,接下来黑客可以做的就是:拉下你的代码、分析你的业务、得到你的数据库连接信息。可想而知风险非常大。

2. 处理方式

2.1 Nginx拒绝访问

从最外层的流量网关禁止访问相关文件,可以在Nginx的对应server下配置:

    # 避免暴露 .git 目录
    location ~ /.git/ {
          deny all;
    }

2.2 Jenkins发布过滤

在Jenkins拉完代码之后会进行编译,之后的部署只需要编译后的文件(tar或者dist目录下的静态资源文件)。对于使用rsync命令推送的代码,可以使用--exclude=.git 排除掉。

rsync -vauP -e  --exclude=.git 'ssh -p 22' /root/.jenkins/workspace/project_xxx/* root@192.168.1.191:/opt/openresty/nginx/html/project_xxx

3. 总结

安全无小事,要了解各个工具的运行机制,避免出现暴露出核心的代码文件。另外还可以通过公有云平台的漏洞检查工具,定期进行审查,防患于未然。

### 解决 GitHub 仓库认证失败问题 当遇到 `GitHub repository not found` 或 `authentication failed` 的错误时,通常是因为本地 Git 配置不正确或者远程 URL 设置有问题。以下是针对该问题的具体解决方案: #### 1. 更新远程仓库 URL 如果当前使用的协议或身份验证方式存在问题,则可以尝试更新远程仓库的 URL 到 HTTPS 协议并加入用户名以便于登录操作[^1]。 ```bash git remote set-url origin https://yourusername@github.com/owner/repo.git ``` 此命令会将现有的远程地址替换为新的包含用户名的形式,从而允许通过 HTTPS 进行更安全的身份验证。 #### 2. 检查全局配置设置 确保已正确定义了用户的电子邮件和名称信息,这对于提交更改到版本控制系统非常重要[^2]。 ```bash git config --global user.email "you@example.com" git config --global user.name "Your Name" ``` 这些基本信息不仅有助于识别贡献者身份,在某些情况下也会影响权限校验过程中的行为表现。 #### 3. 处理 SSL 握手失败的情况 对于因网络环境引起的 SSL 错误 (如 ABAP 中提到的 SSSLERR_SSL_READ),虽然目前此类技术障碍已被克服,但仍需注意后续可能出现的相关认证挑战[^3]。此时建议重新审视个人访问令牌(Personal Access Token, PAT)的有效性和适用范围;必要时创建一个新的PAT,并赋予适当的操作许可级别(比如repo scope)来替代原有的密码机制完成进一步的安全加固措施。 另外还可以考虑启用Git Credential Manager Core工具帮助管理跨平台下的凭证存储需求,简化多设备间的切换流程体验。 --- ### 注意事项 - 如果以上方法仍无法解决问题,请确认目标库是否存在以及是否有足够的读写权限。 - 对敏感数据采取必要的保护手段,切勿随意泄露账号详情给不可信方。
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值