简朴认识Git(dirsearch、githack下载),git走漏(ctfhub)

打印 上一主题 下一主题

主题 869|帖子 869|积分 2607

目录
dirsearch下载地址:
githack下载(一次不乐成可多试几次)
一、什么是Git
1.git布局
2.git常用下令及示例
3.Git走漏原理
二、Git走漏
1.Log
2.Stash
3.Index

工具准备:dirsearch、githack
   dirsearch下载地址:

  
GitHub - maurosoria/dirsearch: Web path scanner

  githack下载(一次不乐成可多试几次)

进入root用户,下载克隆GitHack库

  1. git clone https://github.com/BugScanTeam/GitHack
复制代码
kali下载使用GitHack_kali安装gitclone-CSDN博客


如许就是安装乐成了

使用GitHack
使用到工具 GitHack 来完成,而 CTFHub 上提供的工具需要在 python2 情况中执行
  1. python2 GitHack.py 链接/.git/
复制代码
一、什么是Git

1.git布局

Git的布局和使用_git布局-CSDN博客
   (1)工作区:  .git 所在文件夹    (2)暂存区(stage 或 index):一般存放在  .git 目录下的  index 文件(  .git/index)中,所以把暂存区有时也叫作索引(  index)    (3))本地堆栈(版本库):用于存储各种版本(分支)的信息。  .git 文件就是版本库,此中  的.git/HEAD 文件,它存储着当前分支的名字    (4)长途堆栈:服务器存贮着各种项目,比方国内的  gitee ,国外的  github ,  gitlab 等等  运作过程:(图片来自水印)
创建一个版本库,通过下令git add添加到暂存区,然后通过下令 git commit -m"备注" 添加到版本库,最后通过下令 git push 推送到长途堆栈 。

description:堆栈的形貌信息,主要给gitweb等git托管系统使用
HEAD:即.git/HEAD文件,它存储着当前分支的名字
config:Git堆栈的设置文件
index:这个文件就是暂存区(stage),是一个二进制文件
info:包含堆栈的一些信息
logs:生存全部更新的引用记录
COMMIT_EDITMSG:生存最新的commit message,Git系统不会用到这个文件,是用户一个参考文件
hooks:这个目录存放一些shell脚本,可以设置特定的git下令后触发相应的脚本
refs:这个目录一般包括三个子文件夹,heads、remotes和tags,heads中的文件标识了项目中的各个分支指向的当前commit
objects:全部的Git对象都会存放在这个目录中,对象的SHA1哈希值的前两位是文件夹名称,后38位作为对象文件名
2.git常用下令及示例

GIT常用下令大全——赶紧收藏_git下令大全-CSDN博客
  1. git config --global user.name "Your Name"
  2. git config --global user.email "email@example.com"
  3. //git安装后-指定名称和邮箱
复制代码

  1. pwd        //查看当前目录
复制代码

  1. git init        //初始化,生成.git文件(若该文件隐藏,则使用ls -ah)
复制代码

  1. git log        //查看提交历史记录,从最近到最远,可以看到3次
  2. git log --pretty=oneline        //加参,简洁查看
  3. git reflog        //查看每一次修改历史
复制代码



  1. git add 1.txt  //添加文件
  2. git commit -m "wrote a test file"        //提交文件
  3. git rm 1.txt   //删除文件
  4. git commit -m "remove 1.txt"    //删错了,恢复
复制代码
  1. git status        //查看工作区中文件当前状态
复制代码

  1. git remote        //查看远程库的信息
  2. git remote -v        //查看远程库的详细信息
  3. git remote rm origin        //删除远程仓库(解绑)
复制代码
 

  1. git diff <commit>  //比较现版本与上一版本的区别
  2. git reset <commit> //回滚到上一版本
  3. # 什么都不写 默认 --mixed
  4. git reset --hard <commit>   //回滚到上一版本(并丢弃修改的内容)
  5. # --hard 丢弃修改的内容
复制代码
3.Git走漏原理

Git走漏相关知识点_.git走漏-CSDN博客
   Git是一个可以实现有效控制应用版本的系统,在设置不妥的情况下,大概会将“.git”文件直接摆设到线上情况,就很大概将源代码走漏出去。
  一旦攻击者或者黑客发现这个问题之后,就大概利用其获取网站的源码、数据库等重要资源信息,进而造成严重的危害。
  所以发攻击者只要发现有git走漏,就可以通过相关工具来得到它所走漏的代码,此中会有一些关键信息。
  二、Git走漏

   标题形貌:
  当前大量开发人员使用git举行版本控制,对站点自动摆设。假如设置不妥,大概会将.git文件夹直接摆设到线上情况。这就引起了git走漏漏洞。请尝试使用BugScanTeam的GitHack完成本题。
  1.Log


查察源代码,提示有git走漏(.git leakage)

使用dirsearch扫描,也可发现有git走漏

使用GitHack克隆目录

 扫描乐成后githack会天生一个文件夹dist,里面存放着重新天生的文件

进入新文件,标题提示log,就用git log查察提交历史记录

发现添加了flag(add flag)
法一:git reset回退文件版本
  1. git reset --hard 4ef99b0bb42e1d518d8fd93ab2e41093cb82e7c3
复制代码

提示游标HEAD位于add flag中,去文件夹中打开文件发现flag 

法二:使用git diff文件对比 
  1. git diff 93f0a5663e1393ba385c26bf597296f9bb437a63 4ef99b0bb42e1d518d8fd93ab2e41093cb82e7c3
复制代码

2.Stash

   stash可以理解为git的暂存文件
  源代码提示有git走漏(.git leakage )

  使用dirsearch扫描,也可发现有git走漏

使用GitHack克隆目录

扫描乐成后githack天生一个文件夹dist,里面存放着重新天生的文件

 进入新文件后,与上题一样,先用git log查察提交历史记录发现了add flag的历史,但是发现使用git reset回退文件版本与git diff举行文件对比均无法得到flag。

原因是存放flag的文件仅存在于stash暂存区里面,没有被提交到本地库。一般来说,不能直接在本地库查察或操纵暂存区中的文件。
于是可使用git stash pop提取git的暂存文件
  1. git stash       //备份当前工作区的内容,保存到git栈中,从最近的一次commit中读取相关内容
  2. git stash pop   //从git栈中获取到最近一次stash进去的内容,恢复工作区的内容。获取之后,会删除栈中对应的stash
复制代码
  原历史记录
  

   使用git stash pop提取后 (删除了最近的一次remove flag记录)
  

  可以用ls、cat下令查察,也可直接打开文件 获得flag。 


3.Index

   index可以理解为git的暂存文件
  查察源代码,提示git走漏

步调如上, 使用dirsearch扫描,也可发现有git走漏

使用GitHack克隆目录

扫描乐成后githack天生一个文件夹dist,里面直接存放有重新天生的flag文件

index是暂存区,为什么直接就有flag?
使用git log查察提交历史记录,发现指针直接指向add flag的分支,故查察目录文件直接有flag。


免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?立即注册

x
回复

使用道具 举报

0 个回复

倒序浏览

快速回复

您需要登录后才可以回帖 登录 or 立即注册

本版积分规则

万有斥力

金牌会员
这个人很懒什么都没写!

标签云

快速回复 返回顶部 返回列表