1. 安装Git-cli

winget install --id GitHub.cli

注:以上命令用于在Windows平台CMD执行快捷安装,若需安装其他平台的Git-cli及详细内容,win安装文件一般下载amd64 installer的版本,请访问:https://github.com/cli/cli

2. 使用Git-cli进行身份验证

执行下列命令会进行身份验证并将本地gh工具与远程GitHub账户进行关联

gh auth login

注:执行该命令后会有以下提示

选择平台,这里我选GitHub,并回车
Where do you use GitHub?  [Use arrows to move, type to filter]

>GitHub.com

Other

选择Git操作的协议,这里我选HTTPS,并回车

What is your preferred protocol for Git operations on this host?  [Use arrows to move, type to filter]

>HTTPS

SSH

输入Y或n,确认是否使用GitHub凭证对Git进行身份验证,这里输入Y并回车

Authenticate Git with your GitHub credentials? (Y/n)

选择认证方式,使用何种方式进行认证,使用浏览器进行认证?还是使用Token进行认证?这里我选Login with a web browser,并回车

How would you like to authenticate GitHub CLI?  [Use arrows to move, type to filter]

>Login with a web browser

Paste an authentication token

回车后会提示两条信息:
First copy your one-time code: B543-72FB

Press Enter to open https://github.com/login/device in your browser...

此时按回车,并按照浏览器的提示点击continue,然后将上述的验证码输入浏览器

验证码输入完成后,等待几秒,然后点击Authorize github即可完成验证(若开启了手机GitHub验证,需在手机进行授权)

操作完成后,返回CMD或Git-Bash观察,等待几秒会提示下列信息表示身份认证完成:

Authentication complete.
gh config set -h github.com git_protocol https
Configured git protocol
Logged in as xxxx

3. 使用Git-cli在GitHub上直接创建远程仓库并初始化

先在电脑上任意位置创建一个目录,这里举例为D:\Git_Repo
此时,我先进入Git_Repo目录,打开CMD执行以下命令(习惯Linux命令操作的可使用Git-Bash操作)

gh repo create myproject --private -l MIT -g "C++" --add-readme

注:执行后会输出远程仓库名如:https://github.com/xxxxxxx/myproject,此时GitHub中的远程仓库已经完成创建并初始化完成

myproject    远程仓库名

--private      设置为私有仓库

--add-readme   设置README文件

-l          设置License

-g         设置.gitignore

4. 使用Git-cli克隆GitHub中初始化完成的远程仓库

gh repo clone myproject

注:此时查看当前目录,远程仓库已经克隆到本地了

5. 进入克隆下来的仓库并进行相关操作

cd myproject
touch demo.cpp
echo "#include<iostream>" > demo.cpp
git add .
git commit -m "add a demo file"
git push origin main

至此基本的安装、认证和仓库创建操作已经结束,第5步以后的操作,按需操作即可

6. 查看本地仓库默认主分支

若未配置本地仓库默认主分支,而又先在本地创建仓库,再使用git init命令初始化仓库时,此时的本地仓库默认主分支为master

git config --global init.defaultBranch

注:若执行后无输出,则表示未配置,此时本地仓库的默认主分支可能为master,而不是main,与GitHub远程仓库的默认主分支不同步。因2020年GitHub响应社区呼吁宣布将默认分支名改为main

7. 配置本地仓库默认主分支为main

git config --global init.defaultBranch main

注:此时再执行git init初始化本地仓库,然后将本地创建的仓库推送到远程仓库时,本地仓库的默认主分支与远程仓库的默认主分支一致为main

8. 使用Git-cli删除已创建的远程仓库

gh repo delete myproject

注:在删除仓库时,会提示下列信息,此时等待你的输入,确认要删除此仓库,在冒号后输入your-username/myproject以确认删除,然后回车即可:
输入前提示:Type your-username/myproject to confirm deletion:

输入后提示:Type your-username/myproject to confirm deletion: your-username/myproject

执行删除仓库的命令时,可能会无法删除成功,并提示:

HTTP 403: Must have admin rights to Repository. (https://api.github.com/repos/Rinato-C417/myproject)
This API operation needs the "delete_repo" scope. To request it, run: gh auth refresh -h github.com -s delete_repo

提示的信息大意是:该删除操作需要delete_repo权限

此时需要执行以下命令来获取该权限:

gh auth refresh -h github.com -s delete_repo

作用是更新认证信息并请求删除仓库的delete_repo的权限,执行后需经过GitHub授权后才能继续操作

授权完成后,再次执行第8步的gh repo delete myproject删除仓库操作时,仓库此时即可删除成功

9. 使用Git-cli列出所有仓库

gh repo list

Git命令与Git-cli的更多相关文章

  1. 每日一条 Git 命令:git merge remote master

    每日一条 Git 命令:git merge remote master 当远程的分支更新后,需要将自己的代码与远程的分支合并就用以下这个命令合并. git merge remote master 如果 ...

  2. git命令之git rebase 的用法

    rebase 假设你现在基于远程分支"origin",创建一个叫"mywork"的分支. $ git checkout -b mywork origin 现在我 ...

  3. git命令之git remote的用法

    git remote git  remote -v git init git add xxx git commit -m 'xxx' git remote add origin ssh://softw ...

  4. Git 命令及git服务器

    Linux 服务器上安装git yum -y install git git config  --global user.name "name" git config  --glo ...

  5. 第23月第24天 git命令 .git-credentials git rm --cached git stash clear

    在git push的时候,有时候我们会想办法撤销git commit的内容 1.找到之前提交的git commit的id git log 找到想要撤销的id 2.git reset –hard id ...

  6. git命令之git clone用法

    在使用git来进行版本控制时,为了得一个项目的拷贝(copy),我们需要知道这个项目仓库的地址(Git URL). Git能在许多协议下使用,所以Git URL可能以ssh://, http(s):/ ...

  7. [转]git命令之git remote的用法

    git remote git  remote -v git init git add xxx git commit -m 'xxx' git remote add origin ssh://softw ...

  8. git命令之git tag 给当前分支打标签

    git tag - 标签相关操作 发表于 2011年06月29日 由 机器猫 标签可以针对某一时间点的版本做标记,常用于版本发布. 列出标签 $ git tag # 在控制台打印出当前仓库的所有标签$ ...

  9. git命令之git mergetool vi非正常退出.swp删除不了的问题

    1.git   pull命令产生无法merge的错误 使用了 git  mergetool命令然后...傻逼了 进入了vi操作界面,不会操作,非正常退出... 然后就产生了.swp相关文件,死活删除不 ...

  10. Git命令(Git版本:Linux 2.14.3)

    常用 git status 跟踪状态git commit -m "xxx" yyy.cppgit pull git pushgit mergetool --tool=meld 合并 ...

随机推荐

  1. SqlServer中常用的一些操作语句

    我们在维护数据库数据的时候,通常会用到各种SQL语句对数据进行操作或者维护,如:查看某个数据库中有哪些用户数据表.每个数据表中总共有多少条数据-- SqlServer官方地址:https://lear ...

  2. DeepSeek 不再卡顿,从此告别服务器繁忙,请稍后再试(建议收藏!)

    大家好,我是六哥. 由于DeepSeek真的太火了,也许你也跟我一样,常会遇到这样的情况: 真的让人抓狂,10条回复里常常有9条是"服务器blabla,请稍后重试",看到这话,就问 ...

  3. Arduino语法--运算符

    本节介绍最常用的一些Arduino运算符,包括赋值运算符.算数运算符.关系运算符.逻辑运算符和递增/减运算符. 一. 赋值运算符 =(等于)为指定某个变量的值,例如:A=x,将x变量的值放入A变量. ...

  4. MONGODB数据备份与导入

    主要记录下在mongo 3.0的操作 备份示例 ./mongodump -h localhost -d liongo -o ./ 还原示例 错误方式: ./mongorestore -h 127.0. ...

  5. 移动硬盘插入win10检测到却不显示盘符解决方法

    1.开始菜单中的设置-----设备. 2.选择"蓝牙和其他设备" 3.在其他设备栏中就能看到检测到的移动硬盘,点击删除设备后重新插入移动硬盘即可在此电脑上显示盘符.

  6. DeepSeek-R1的“思考”艺术,你真的了解吗?

    大家好~,这里是AI粉嫩特攻队!今天咱们来聊聊一个有趣的话题--DeepSeek-R1到底什么时候会"思考",什么时候又会选择"偷懒"? 最近有朋友问我:&qu ...

  7. 【软件开发】Doxygen使用笔记

    [软件开发]Doxygen 使用笔记 Doxygen 是通过代码注释生成文档的事实标准,借用该工具可以将文档内容与代码写在一起方便维护. https://github.com/doxygen/doxy ...

  8. 动态能力理论&知识管理理论--商业之所见

    动态能力理论:企业整合,建立和再配置内外部资源以适应快速变化环境的能力. (1)"动态"指的是适应不断变化的环境,企业必须具有不断更新自身能力的能力: (2)"能力&qu ...

  9. Java进阶 - [1-5] 集合容器

    ArrayList add 1.先确认是否需要扩容,如果需要,则进行扩容操作ensureExplicitCapacity. 2.进行赋值 elementData[size++] = e; 扩容 1.如 ...

  10. SICK Ranger3源码分析——断线重连

    前言 本文可在https://paw5zx.github.io/SICK-Ranger3-source-code-analysis-01/中阅读,体验更加 简单分析一下SICK Ranger3源码中断 ...