ebody: Git - Codezeile mit API Key in jeder Datei aus vorherigen commits ändern.

Beitrag lesen

Hallo,

  1. Ist es möglich mit Git eine Codezeile in jeder Datei, auch aus vorherigen commits zu ändern?

Hierfür habe ich eine Möglichkeit gefunden und konnte in einem sehr übersichtlichen Test Projekt den Code in vergangenen Commits ändern. Wenn ein Repository aber schon mit anderen geteilt wurde, sollte man vorab gut abwägen, ob das sinnvoll ist oder wenn man Verzeichnisse und Dateien hatte, deren Name geändert, die gelöscht, verschoben wurden, kann das bestimmt ganz schön mühselig werden.

Man kann das mit rebase und commit --amend umsetzen.

Hier eine grobe Übersicht und ein Beispiel:

In dem markierten Commit habe ich in der index.html einen API Key eingetragen: <p>My Api Key: 123456</p> Die index.html ist in den darauf folgenden Commits mit dem API Key ebenfalls vorhanden und möchte in jedem Commit den API Key im Code ändern in: <p>My Api Key: strApiKey</p>

Git Commits

  1. git rebase -i f831c62
  2. Fenster öffnet sich, wo Commits aufgelistet werden. Befehl für gewünschten Commit wählen: edit ... 9013402
  3. Änderung in der index.html vornehmen: <p>My Api Key: strApiKey</p>
  4. git add .
  5. git commit --amend
  6. Fenster öffnet sich, Commit bestätigen indem man es einfach schließt.
  7. git rebase --continue
  8. Man befindet sich jetzt im nächsten Commit 4b31c1a und muss Konflikte lösen. In der betroffenen Datei (index.html) "Accept Both Changes" wählen und den Code anpassen.
  9. git add .
  10. git rebase --continue
  11. Man befindet sich jetzt im nächsten (und letzten) Commit ef70ecc und muss Konflikte lösen. In der betroffenen Datei (index.html) "Accept Both Changes" wählen und den Code anpassen.
  12. git add .
  13. git rebase --continue

Fertig. Die Commit ID´s haben sich danach geändert und der Code in jeder index.html ist jetzt <p>My Api Key: strApiKey</p>.

In diesem Kurs https://codewithmosh.com/p/the-ultimate-git-course, den ich übrigens sehr empfehlen kann, wird das alles sehr gut erklärt und gezeigt im Video im Kurs Teil "9- Amending an Earlier Commit".

Zu 2. Gibt es evtl. ein Zeichen, welches man vor eine Codezeile setzt und so nicht committed wird. Ähnlich wie Dateien, die man in der .gitignore Datei einträgt?

Sensible Daten lager ich jetzt immer aus und binde sie ein. Ich habe eine hide.js erstellt, zuvor in der .gitignore eingetragen, in der hide.js var strApiKey = '123456'; Die hide.js binde ich in die jeweilige Datei ein, wo ich sie brauche und kann dort strApiKey verwenden, wenn ich den API Key benötige.

Gruß ebody