githubにGit接続でpush/pullするとエラーになる
githubでソース管理をしているエンジニアは非常に多いですが、コマンドラインからgitコマンドを実行して、例えばこんなエラーに遭遇したことはありませんか?
$ git pull
Password:
error: The requested URL returned error: 403 Forbidden while accessing https://〇〇〇@github.com/〇〇〇/〇〇〇.git/info/refs
fatal: HTTP request failed
とか
$ git pull
ERROR: You're using an RSA key with SHA-1, which is no longer allowed. Please use a newer client or a different key type.
Please see https://github.blog/2021-09-01-improving-git-protocol-security-github/ for more information.
fatal: The remote end hung up unexpectedly
などセキュリティ強化のため続けざまに仕様が変更され、様々なエラーが出るようになってきてます。
Githubへの接続が403エラーになる原因
単純にパスワードなどのアカウント認証情報が間違っているなどの場合も以前はこのエラーが出ました。
「error: The requested URL returned error: 403 Forbidden while accessing https://〇〇〇」
しかし、パスワードはあっているのに現在エラーが出るようなら、Github自体の仕様変更が原因かもしれません。
セキュリティの仕様変更① パスワードアクセスの廃止
Githubの公式サイトより「Git操作のトークン認証要件」
https://github.blog/2020-12-15-token-authenti…
一言でいうと、「2021年8月13日以降、GitHub.comでGit操作を認証する際にアカウントパスワードを受け付けなくなります」ということです。
セキュリティの仕様変更② gitプロトコル廃止とSSHの要件変更
もう1つは
GitHubでのGitプロトコルセキュリティの改善
https://github.blog/2021-09-01-improving-git-…
こちらの概要は
※gitプロトコル廃止
※2021/11~ SSH用のECDSAおよびEd25519ホストキーが使用可能に。
※2022/3 DSAキー廃止、SHA-1署名のRSAキー廃止、SHA-2のみ利用可能に。
こちらも同様に対応していく必要があります。
ではどうしたらよいのでしょうか?
その対応方法を2つ紹介します!
Githubの仕様変更の対処方法
①SSH接続の認証に変更する
SSH接続を使える場合は、こちらで設定したほうが便利です。
Gitのバージョンが1.7.10未満の場合もこちらを選んだ方がよいです。
SSH接続の認証に切り替えるには以下の3ステップが必要です。
- ステップ① SSHの秘密鍵・公開鍵を作成
- ステップ② Githubに公開鍵を登録
- ステップ③ GitをSSH接続に設定
ステップ① SSHの秘密鍵・公開鍵を作成
$ cd ~/.ssh
×ダメ(旧) $ ssh-keygen -t rsa -b 4096 -C “****@sample.com”
〇正解(新) $ ssh-keygen -t ecdsa -b 521 -C “****@sample.com”
いくつか質問されますが、パスフレーズ以外はEnterでスキップでかまいません。
パスフレーズを求められるので入力しましょう。
パスフレーズはこの鍵を認証するためのパスワードの呼び名です。
これからはパスワードでなくこのパスフレーズを使います。
空でも設定できますが、なるべくやめておいたほうがよいでしょう。
$ ls
id_ecdsa id_ecdsa.pub
ファイルが2つできました。
id_ecdsa.pub が公開鍵です。
id_ecdsa は秘密鍵なのでこれは絶対に他人に渡してはいけません。
自分だけで保存しておいてください。
ステップ② Githubに公開鍵を登録
https://github.com/にログイン
プロフィールアイコンから「Settings」
data:image/s3,"s3://crabby-images/60ddd/60ddd82fa4a7f8b8833f067e420e94f881e73c63" alt=""
左メニューから「SSH and GPG Keys」
data:image/s3,"s3://crabby-images/e3e4a/e3e4ad95781cd304a8c7808358d3d9bbdffc0306" alt=""
「New SSH key」ボタン
data:image/s3,"s3://crabby-images/d79ff/d79ff4fba24b5ba38e87c95eff113286383c4087" alt=""
Titleは何でもいいので、Keyに先ほどのid_ecdsa.pubファイルの内容(暗号化された文字列)を貼り付けます。
data:image/s3,"s3://crabby-images/e1d7b/e1d7b355eca8ce7e75cb1d6a9d3583e4baef35ba" alt=""
これで登録は完了です。
※古いキーが登録されている場合は削除しましょう
ステップ③ GitをSSH接続に設定
キーの登録が成功してるかどうかSSH接続を確認します。
$ ssh -T git@github.com
The authenticity of host 'github.com (52.69.186.44)' can't be established.
RSA key fingerprint is
Are you sure you want to continue connecting (yes/no)? yes ←yes
Warning: Permanently added 'github.com,52.69.186.44' (RSA) to the list of known hosts.
Enter passphrase for key '/home/****/.ssh/id_ecdsa': ←パスフレーズを入力
Hi *******! You've successfully authenticated, but GitHub does not provide shell access. ←これが出れば成功
また、これまでの設定からSSH用の設定に変更します。
git remote set-url origin git@github.com:<Gitユーザー名>/<リポジトリ名>.git
設定確認
git remote -v
これで設定は完了です。
実際にpullしてみましょう。
$ git pull
Enter passphrase for key '/home/****/.ssh/id_ecdsa': ← パスフレーズを入力
Already up-to-date.
成功!!
これまでのパスワード入力となんら変わらない操作で接続できました。
おまけ
コマンドラインだけではなくGUIのクライアントgitアプリケーションをつかっている場合もあると思うので、その場合はそちらも変更しておきましょう
Sourcetreeの場合
メニュー>ツール>オプション
data:image/s3,"s3://crabby-images/71d4a/71d4a7feed10c2b2283fd6cb01bbad31671555cd" alt=""
以下のように選択して、今回使ったSSHで更新します。
data:image/s3,"s3://crabby-images/5b946/5b94656585ac667bb8f8a75163ad03c05a3d4338" alt=""
②トークンを使った認証方式に変更する
トークンを使う方法を紹介します。
コマンドラインのGitバージョン1.7.10未満の場合は対応していません。
https://github.com/にログイン
プロフィールアイコンから「Settings」
data:image/s3,"s3://crabby-images/9f6e7/9f6e78eaad2ec786b835522a987ed2e7afb7ebf6" alt=""
左メニューの「Developer Settings」
data:image/s3,"s3://crabby-images/794e5/794e52baa7cacdd2b2c39fe86b9e4f52a1bcf900" alt=""
左メニューの「Personal access tokens」
data:image/s3,"s3://crabby-images/3ac2a/3ac2a89594aadc3ed7414787a46ffb8c995ee2cf" alt=""
右上の「Generate new token」
data:image/s3,"s3://crabby-images/1a558/1a558fec0ce50d032324bb4eb1891dd48ad0704f" alt=""
トークンを新規作成します。
Note→トークン名などを好きな文字列を入力。
Expiration→トークンの期限を入力。期限なしもあり。
Select scopes→権限。コマンドラインから使いたい時はrepoを。
data:image/s3,"s3://crabby-images/816ab/816abedb10120e9447eae6675ed19d1dfc2ed8e7" alt=""
アクセストークン文字列が出来ました。
こちらをコピーします。
data:image/s3,"s3://crabby-images/1c764/1c764596ede7a4308b96bfc52aa7e5af575119da" alt=""
これで普通にパスワード代わりにアクセストークンを入力することでアクセスできるようになります。
その他の設定を変える必要はありません。
毎回、保存するのが面倒な場合は、以下のようにすることでトークンをキャッシュし入力せずにアクセスすることができます。
※注) git 1.7.10以上が必要
#1時間(3600秒)の場合
$ git config --global credential.helper 'cache --timeout=3600'
コメント