<dd id="3pk9i"><optgroup id="3pk9i"><video id="3pk9i"></video></optgroup></dd>
<rp id="3pk9i"></rp>

<dd id="3pk9i"><track id="3pk9i"></track></dd>
      1. <th id="3pk9i"></th>
        1. <ol id="3pk9i"><ruby id="3pk9i"></ruby></ol>

        2. 分享一個重要的Git技巧,能保護核心代碼!-世界動態

          來源:php中文網 | 2022-12-30 17:57:40 |

          前段時間完成了一個核心代碼保護的功能,目標在關鍵代碼被修改及時同步給其他人,避免沒經過 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 <<<pull.rebase=true    //默認 pull 是 merge 還是 rebase

          如何獲取當前分支

          為了減少提示頻率,最好只檢測核心的分支的提交(包括 merge commit)。如何獲取當前分支呢?有一個簡單的方式:

          git symbolic-ref --short HEAD

          這句命令主要包括兩個關鍵字:symbolic-refHEAD。

          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非常強大,它可以有這些使用場景:

          獲取本地和遠端的 commit 差異獲取指定時間內的提交記錄,可以具體到誰、什么時候、修改了哪些獲取具體某次提交修改的文件

          上面我們使用的參數 @{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中文網其它相關文章!

          關鍵詞: 核心代碼

          中文字幕在线观看2021
          <dd id="3pk9i"><optgroup id="3pk9i"><video id="3pk9i"></video></optgroup></dd>
          <rp id="3pk9i"></rp>

          <dd id="3pk9i"><track id="3pk9i"></track></dd>
            1. <th id="3pk9i"></th>
              1. <ol id="3pk9i"><ruby id="3pk9i"></ruby></ol>