前段时间完成了一个核心代码保护的功能,目标在关键代码被修改及时同步给其他人,避免没经过 review 就上线导致问题,提示的效果图如下:
在实现的过程中,用到一些平时使用不多的 Git 技巧,这篇文章来总结一下。
【资料图】
如何获取当前提交用户信息
这个比较简单,通过 git config user.name
即可:
04318deMacBook-Pro % git config user.namezhangshixin
登录后复制
git config 保存了很多配置信息,其中常用的有自定义快捷键、用户信息、项目地址、分支信息等:
504318deMacBook-Pro % git config -l//快捷键 begin >>> 我们可以定义自己的 git 快捷键alias.st=status alias.co=checkoutalias.cb=checkoutalias.p=pullalias.pr=pullalias.pu=pushalias.cm=commitalias.br=branchalias.cm=commitalias.undo=resetalias.rbc=rebasealias.save=stashalias.pop=stash//快捷键 end <<< 我们可以定义自己的 git 快捷键//用户名称和邮箱 begin >>>user.name=zhangshixinuser.email=shixin.zhang@xxx.com//用户名称和邮箱 end <</项目和分支信息 begin >>>remote.origin.url=git@gitlab.xxx:android/xxx.gitremote.origin.fetch=+refs/heads/*:refs/remotes/origin/*branch.master.remote=originbranch.master.merge=refs/heads/masterbranch.Canary.remote=originbranch.Canary.merge=refs/heads/Canary//项目和分支信息 end <<登录后复制
如何获取当前分支
为了减少提示频率,最好只检测核心的分支的提交(包括 merge commit)。如何获取当前分支呢?有一个简单的方式:
git symbolic-ref --short HEAD
登录后复制
这句命令主要包括两个关键字:symbolic-ref
和 HEAD
。
symbolic-ref
可以读取、修改和删除符号引用。
什么是符号引用呢?它表示一个以 refs 开头的文件(比如 refs/heads/develop),这个文件保存着本地每个分支当前所处 commit。
我们可以打开 git 项目的 .git 文件夹,在其中的 refs/heads 文件夹中会保存各个分支当前所指向的 commit:
HEAD
指的是 .git/HEAD,就是一个文件,保存着当前指向的符号引用:
因此 git symbolic-ref --short HEAD
的含义就是读取 .git/HEAD 文件的内容,我这里就是 refs/heads/develop 文件,因此就得出当前分支是 develop 分支。
如何获取本地未 push 的所有 commit
有时候我们会在本地提交多次后再 push,因此在拦截 push 时,需要获取到当前要 push 的所有 commit 信息,然后获取每个 commit 修改的文件。
获取要 push 信息可以通过 git log @{u}.. --oneline
:
504318deMacBook-Pro ShixinDemo % git log @{u}.. --oneline4e4655b (HEAD -> master) 拦截跳转f947180 修改文件
登录后复制
git log
非常强大,它可以有这些使用场景:
上面我们使用的参数 @{u}..
就是表示获取本地和远端的 commit 差异,然后 --oneline
表示不打印具体信息,只打印 short commit id 和 commit message。
如果要获取指定时间内的提交记录,可以这样:
git log --pretty="%an(%cd) %h - %s" --since="2022-09-01" --no-merges --name-status
登录后复制
命令执行结果:
504318deMacBook-Pro ShixinDemo % git log --pretty="%an(%cd) %h - %s" --since="2022-09-01" --no-merges --name-statuszhangshixin(Fri Dec 16 22:34:49 2022 +0800) 4e4655b - 拦截跳转M app/src/main/java/com/example/heicdemo/MainActivity.ktzhangshixin(Fri Dec 16 22:34:30 2022 +0800) f947180 - 修改文件M .idea/gradle.xmlM .idea/misc.xmlD .idea/runConfigurations.xmlA android10_dem_heic_output.heicA app/src/main/assets/android10_dem_heic_output.heicR100 app/src/main/res/drawable/mushroom.jpg app/src/main/assets/mushroom.jpgA app/src/main/assets/mushroom.webpM app/src/main/java/com/example/heicdemo/MainActivity.ktA app/src/main/res/drawable/mushroom.webpM app/src/main/res/layout/activity_main.xml
登录后复制
pretty
的参数用于指定打印的内容和格式;since
参数用于指定查看时间范围;no-merges
表示过滤掉 merge 时生成的额外 commit;name-status
表示展示出文件的修改状态(M 表示修改;D 表示删除;A 表示增加;R 表示重命名)。
如何获取每个 commit 修改的文件
知道 commit ID 后,可以通过 git show --pretty="" --name-only $commitId
获取这个 commit 影响的信息:
04318deMacBook-Pro ShixinDemo % git show --pretty="" --name-only 4e4655b app/src/main/java/com/example/shixindemo/MainActivity.kt
登录后复制
git show
可以用来查看 commit 的 commit message 和修改的文件、文件具体内容等信息。上面的代码中我们使用了 name-only
参数表示只要查看修改的文件即可。
总结
这篇文章介绍了通过拦截 git push 时,获取当前用户、当前分支、未 push 的 commit 和修改的文件等命令,通过组合这些命令,就可以实现一个核心代码保护功能了!
以上就是分享一个重要的Git技巧,能保护核心代码!的详细内容,更多请关注php中文网其它相关文章!